Part Number Hot Search : 
40N03 5GLSITE1 AC100 MJE171 ZTX555 CNW84 2TRPB 101MF
Product Description
Full Text Search
 

To Download R5S61650C Datasheet File

  If you can't view the Datasheet, Please click here to try to view without PDF Reader .  
 
 


  Datasheet File OCR Text:
 REJ09B0311-0200
The revision list can be viewed directly by clicking the title page. The revision list summarizes the locations of revisions and additions. Details should always be checked by referring to the relevant text.
32
H8SX/1650Group
Hardware Manual
Renesas 32-Bit CISC Microcomputer H8SX Family / H8SX/1600 Series H8SX/1650C R5S61650C
All information contained in this material, including products and product specifications at the time of publication of this material, is subject to change by Renesas Technology Corp. without notice. Please review the latest information published by Renesas Technology Corp. through various means, including the Renesas Technology Corp. website (http://www.renesas.com).
Rev.2.00 Revision Date: Jun. 28, 2007
Rev.2.00 Jun. 28, 2007 Page ii of xxii
Notes regarding these materials
1. This document is provided for reference purposes only so that Renesas customers may select the appropriate Renesas products for their use. Renesas neither makes warranties or representations with respect to the accuracy or completeness of the information contained in this document nor grants any license to any intellectual property rights or any other rights of Renesas or any third party with respect to the information in this document. 2. Renesas shall have no liability for damages or infringement of any intellectual property or other rights arising out of the use of any information in this document, including, but not limited to, product data, diagrams, charts, programs, algorithms, and application circuit examples. 3. You should not use the products or the technology described in this document for the purpose of military applications such as the development of weapons of mass destruction or for the purpose of any other military use. When exporting the products or technology described herein, you should follow the applicable export control laws and regulations, and procedures required by such laws and regulations. 4. All information included in this document such as product data, diagrams, charts, programs, algorithms, and application circuit examples, is current as of the date this document is issued. Such information, however, is subject to change without any prior notice. Before purchasing or using any Renesas products listed in this document, please confirm the latest product information with a Renesas sales office. Also, please pay regular and careful attention to additional and different information to be disclosed by Renesas such as that disclosed through our website. (http://www.renesas.com ) 5. Renesas has used reasonable care in compiling the information included in this document, but Renesas assumes no liability whatsoever for any damages incurred as a result of errors or omissions in the information included in this document. 6. When using or otherwise relying on the information in this document, you should evaluate the information in light of the total system before deciding about the applicability of such information to the intended application. Renesas makes no representations, warranties or guaranties regarding the suitability of its products for any particular application and specifically disclaims any liability arising out of the application and use of the information in this document or Renesas products. 7. With the exception of products specified by Renesas as suitable for automobile applications, Renesas products are not designed, manufactured or tested for applications or otherwise in systems the failure or malfunction of which may cause a direct threat to human life or create a risk of human injury or which require especially high quality and reliability such as safety systems, or equipment or systems for transportation and traffic, healthcare, combustion control, aerospace and aeronautics, nuclear power, or undersea communication transmission. If you are considering the use of our products for such purposes, please contact a Renesas sales office beforehand. Renesas shall have no liability for damages arising out of the uses set forth above. 8. Notwithstanding the preceding paragraph, you should not use Renesas products for the purposes listed below: (1) artificial life support devices or systems (2) surgical implantations (3) healthcare intervention (e.g., excision, administration of medication, etc.) (4) any other purposes that pose a direct threat to human life Renesas shall have no liability for damages arising out of the uses set forth in the above and purchasers who elect to use Renesas products in any of the foregoing applications shall indemnify and hold harmless Renesas Technology Corp., its affiliated companies and their officers, directors, and employees against any and all damages arising out of such applications. 9. You should use the products described herein within the range specified by Renesas, especially with respect to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation characteristics, installation and other product characteristics. Renesas shall have no liability for malfunctions or damages arising out of the use of Renesas products beyond such specified ranges. 10. Although Renesas endeavors to improve the quality and reliability of its products, IC products have specific characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Please be sure to implement safety measures to guard against the possibility of physical injury, and injury or damage caused by fire in the event of the failure of a Renesas product, such as safety design for hardware and software including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other applicable measures. Among others, since the evaluation of microcomputer software alone is very difficult, please evaluate the safety of the final products or system manufactured by you. 11. In case Renesas products listed in this document are detached from the products to which the Renesas products are attached or affixed, the risk of accident such as swallowing by infants and small children is very high. You should implement safety measures so that Renesas products may not be easily detached from your products. Renesas shall have no liability for damages arising out of such detachment. 12. This document may not be reproduced or duplicated, in any form, in whole or in part, without prior written approval from Renesas. 13. Please contact a Renesas sales office if you have any questions regarding the information contained in this document, Renesas semiconductor products, or if you have any other inquiries.
Rev.2.00 Jun. 28, 2007 Page iii of xxii
General Precautions in the Handling of MPU/MCU Products
The following usage notes are applicable to all MPU/MCU products from Renesas. For detailed usage notes on the products covered by this manual, refer to the relevant sections of the manual. If the descriptions under General Precautions in the Handling of MPU/MCU Products and in the body of the manual differ from each other, the description in the body of the manual takes precedence. 1. Handling of Unused Pins Handle unused pins in accord with the directions given under Handling of Unused Pins in the manual. The input pins of CMOS products are generally in the high-impedance state. In operation with an unused pin in the open-circuit state, extra electromagnetic noise is induced in the vicinity of LSI, an associated shoot-through current flows internally, and malfunctions occur due to the false recognition of the pin state as an input signal become possible. Unused pins should be handled as described under Handling of Unused Pins in the manual. 2. Processing at Power-on The state of the product is undefined at the moment when power is supplied. The states of internal circuits in the LSI are indeterminate and the states of register settings and pins are undefined at the moment when power is supplied. In a finished product where the reset signal is applied to the external reset pin, the states of pins are not guaranteed from the moment when power is supplied until the reset process is completed. In a similar way, the states of pins in a product that is reset by an on-chip power-on reset function are not guaranteed from the moment when power is supplied until the power reaches the level at which resetting has been specified. 3. Prohibition of Access to Reserved Addresses Access to reserved addresses is prohibited. The reserved addresses are provided for the possible future expansion of functions. Do not access these addresses; the correct operation of LSI is not guaranteed if they are accessed. 4. Clock Signals After applying a reset, only release the reset line after the operating clock signal has become stable. When switching the clock signal during program execution, wait until the target clock signal has stabilized. When the clock signal is generated with an external resonator (or from an external oscillator) during a reset, ensure that the reset line is only released after full stabilization of the clock signal. Moreover, when switching to a clock signal produced with an external resonator (or by an external oscillator) while program execution is in progress, wait until the target clock signal is stable. 5. Differences between Products Before changing from one product to another, i.e. to one with a different type number, confirm that the change will not lead to problems. The characteristics of MPU/MCU in the same group but having different type numbers may differ because of the differences in internal memory capacity and layout pattern. When changing to products of different type numbers, implement a system-evaluation test for each of the products.
Rev.2.00 Jun. 28, 2007 Page iv of xxii
How to Use This Manual
1. Objective and Target Users This manual was written to explain the hardware functions and electrical characteristics of this LSI to the target users, i.e. those who will be using this LSI in the design of application systems. Target users are expected to understand the fundamentals of electrical circuits, logic circuits, and microcomputers. This manual is organized in the following items: an overview of the product, descriptions of the CPU, system control functions, and peripheral functions, electrical characteristics of the device, and usage notes.
When designing an application system that includes this LSI, take all points to note into account. Points to note are given in their contexts and at the final part of each section, and in the section giving usage notes.
The list of revisions is a summary of major points of revision or addition for earlier versions. It does not cover all revised items. For details on the revised points, see the actual locations in the manual.
The following documents have been prepared for the H8SX/1650 Group. Before using any of the documents, please visit our web site to verify that you have the most up-to-date available version of the document.
Document Type Data Sheet Hardware Manual Contents Document Title Document No. This manual
Overview of hardware and electrical characteristics Hardware specifications (pin assignments, memory maps, peripheral specifications, electrical characteristics, and timing charts) and descriptions of operation Detailed descriptions of the CPU and instruction set Examples of applications and sample programs Preliminary report on the specifications of a product, document, etc. H8SX/1650 Group Hardware Manual
Software Manual Application Note Renesas Technical Update
H8SX Family Software Manual
REJ09B0102
The latest versions are available from our web site.
Rev.2.00 Jun. 28, 2007 Page v of xxii
2. Description of Numbers and Symbols Aspects of the notations for register names, bit names, numbers, and symbolic names in this manual are explained below.
(1) Overall notation In descriptions involving the names of bits and bit fields within this manual, the modules and registers to which the bits belong may be clarified by giving the names in the forms "module name"."register name"."bit name" or "register name"."bit name". (2) Register notation The style "register name"_"instance number" is used in cases where there is more than one instance of the same function or similar functions. [Example] CMCSR_0: Indicates the CMCSR register for the compare-match timer of channel 0. (3) Number notation Binary numbers are given as B'nnnn (B' may be omitted if the number is obviously binary), hexadecimal numbers are given as H'nnnn or 0xnnnn, and decimal numbers are given as nnnn. [Examples] Binary: B'11 or 11 Hexadecimal: H'EFA0 or 0xEFA0 Decimal: 1234 (4) Notation for active-low An overbar on the name indicates that a signal or pin is active-low. [Example] WDTOVF
(4) (2)
14.2.2 Compare Match Control/Status Register_0, _1 (CMCSR_0, CMCSR_1)
CMCSR indicates compare match generation, enables or disables interrupts, and selects the counter input clock. Generation of a WDTOVF signal or interrupt initializes the TCNT value to 0.
14.3 Operation
14.3.1 Interval Count Operation
When an internal clock is selected with the CKS1 and CKS0 bits in CMCSR and the STR bit in CMSTR is set to 1, CMCNT starts incrementing using the selected clock. When the values in CMCNT and the compare match constant register (CMCOR) match, CMCNT is cleared to H'0000 and the CMF flag in CMCSR is set to 1. When the CKS1 and CKS0 bits are set to B'01 at this time, a f/4 clock is selected.
Rev. 0.50, 10/04, page 416 of 914
(3)
Note: The bit names and sentences in the above figure are examples and have nothing to do with the contents of this manual.
Rev.2.00 Jun. 28, 2007 Page vi of xxii
3. Description of Registers Each register description includes a bit chart, illustrating the arrangement of bits, and a table of bits, describing the meanings of the bit settings. The standard format and notation for bit charts and tables are described below.
[Bit Chart]
Bit: 15 Initial value: R/W: 0 R/W 14 0 R/W 13 12 11 10 0 R 9 1 R 8 0 R/W 7 0 R/W 6 0 R/W 5 0 R/W 4 Q 0 R/W 3 2 1 0 IFE 0 R/W
ASID2 ASID1 ASID0 0 R/W 0 R/W 0 R/W
ACMP2 ACMP1 ACMP0 0 R/W 0 R/W 0 R/W
[Table of Bits]
(1) Bit 15 14 13 to 11 10 9
(2) Bit Name - - ASID2 to ASID0 - - -
(3)
(4) Description
(5) Reserved These bits are always read as 0. Address Identifier These bits enable or disable the pin function. Reserved This bit is always read as 0. Reserved This bit is always read as 1.
Initial Value R/W 0 0 All 0 0 1 0 R R R/W R R
Note: The bit names and sentences in the above figure are examples, and have nothing to do with the contents of this manual.
(1) Bit Indicates the bit number or numbers. In the case of a 32-bit register, the bits are arranged in order from 31 to 0. In the case of a 16-bit register, the bits are arranged in order from 15 to 0. (2) Bit name Indicates the name of the bit or bit field. When the number of bits has to be clearly indicated in the field, appropriate notation is included (e.g., ASID[3:0]). A reserved bit is indicated by "-". Certain kinds of bits, such as those of timer counters, are not assigned bit names. In such cases, the entry under Bit Name is blank. (3) Initial value Indicates the value of each bit immediately after a power-on reset, i.e., the initial value. 0: The initial value is 0 1: The initial value is 1 -: The initial value is undefined (4) R/W For each bit and bit field, this entry indicates whether the bit or field is readable or writable, or both writing to and reading from the bit or field are impossible. The notation is as follows: R/W: The bit or field is readable and writable. R/(W): The bit or field is readable and writable. However, writing is only performed to flag clearing. R: The bit or field is readable. "R" is indicated for all reserved bits. When writing to the register, write the value under Initial Value in the bit chart to reserved bits or fields. W: The bit or field is writable. (5) Description Describes the function of the bit or field and specifies the values for writing.
Rev.2.00 Jun. 28, 2007 Page vii of xxii
4. Description of Abbreviations The abbreviations used in this manual are listed below.
*
Abbreviations specific to this product
Description Bus controller Clock pulse generator Data transfer controller Interrupt controller Programmable pulse generator Serial communication interface 8-bit timer 16-bit timer pulse unit Watchdog timer
Abbreviation BSC CPG DTC INTC PPG SCI TMR TPU WDT
* Abbreviations other than those listed above
Abbreviation ACIA bps CRC DMA DMAC GSM Hi-Z IEBus I/O IrDA LSB MSB NC PLL PWM SFR SIM UART VCO Description Asynchronous communication interface adapter Bits per second Cyclic redundancy check Direct memory access Direct memory access controller Global System for Mobile Communications High impedance Inter Equipment Bus (IEBus is a trademark of NEC Electronics Corporation.) Input/output Infrared Data Association Least significant bit Most significant bit No connection Phase-locked loop Pulse width modulation Special function register Subscriber Identity Module Universal asynchronous receiver/transmitter Voltage-controlled oscillator
All trademarks and registered trademarks are the property of their respective owners.
Rev.2.00 Jun. 28, 2007 Page viii of xxii
Contents
Section 1 Overview................................................................................................1
1.1 Features................................................................................................................................. 1 1.1.1 Applications .......................................................................................................... 1 1.1.2 Overview of Functions.......................................................................................... 2 List of Products..................................................................................................................... 7 Block Diagram...................................................................................................................... 8 Pin Assignments ................................................................................................................... 9 Pin Functions ...................................................................................................................... 10
1.2 1.3 1.4 1.5
Section 2 CPU......................................................................................................15
2.1 2.2 Features............................................................................................................................... 15 CPU Operating Modes........................................................................................................ 17 2.2.1 Normal Mode...................................................................................................... 17 2.2.2 Middle Mode....................................................................................................... 19 2.2.3 Advanced Mode.................................................................................................. 20 2.2.4 Maximum Mode ................................................................................................. 21 Instruction Fetch ................................................................................................................. 23 Address Space..................................................................................................................... 23 Registers ............................................................................................................................. 24 2.5.1 General Registers................................................................................................ 25 2.5.2 Program Counter (PC) ........................................................................................ 26 2.5.3 Condition-Code Register (CCR)......................................................................... 26 2.5.4 Extended Control Register (EXR) ...................................................................... 28 2.5.5 Vector Base Register (VBR)............................................................................... 28 2.5.6 Short Address Base Register (SBR).................................................................... 28 2.5.7 Multiply-Accumulate Register (MAC) ............................................................... 29 2.5.8 Initial Register Values......................................................................................... 29 Data Formats....................................................................................................................... 30 2.6.1 General Register Data Formats ........................................................................... 30 2.6.2 Memory Data Formats ........................................................................................ 31 Instruction Set ..................................................................................................................... 32 2.7.1 Instructions and Addressing Modes.................................................................... 34 2.7.2 Table of Instructions Classified by Function ...................................................... 38 2.7.3 Basic Instruction Formats ................................................................................... 49 Addressing Modes and Effective Address Calculation....................................................... 50 2.8.1 Register Direct--Rn ........................................................................................... 51
2.3 2.4 2.5
2.6
2.7
2.8
Rev.2.00 Jun. 28, 2007 Page ix of xxii
2.8.2 2.8.3
2.9
Register Indirect--@ERn................................................................................... 51 Register Indirect with Displacement--@(d:2, ERn), @(d:16, ERn), or @(d:32, ERn)...................................................................................................... 51 2.8.4 Index Register Indirect with Displacement--@(d:16,RnL.B), @(d:32,RnL.B), @(d:16,Rn.W), @(d:32,Rn.W), @(d:16,ERn.L), or @(d:32,ERn.L)................. 51 2.8.5 Register Indirect with Post-Increment, Pre-Decrement, Pre-Increment, or Post-Decrement--@ERn+, @-ERn, @+ERn, or @ERn- ............................ 52 2.8.6 Absolute Address--@aa:8, @aa:16, @aa:24, or @aa:32................................... 53 2.8.7 Immediate--#xx:8, #xx:16, or #xx:32................................................................ 54 2.8.8 Program-Counter Relative--@(d:8, PC) or @(d:16, PC) .................................. 55 2.8.9 Program-Counter Relative with Index Register-- @(RnL.B, PC), @(Rn.W, PC), or @(ERn.L, PC).............................................. 55 2.8.10 Memory Indirect--@@aa:8 ............................................................................... 55 2.8.11 Extended Memory Indirect--@@vec:7 ............................................................. 56 2.8.12 Effective Address Calculation ............................................................................ 56 2.8.13 MOVA Instruction.............................................................................................. 58 Processing States ................................................................................................................ 59
Section 3 MCU Operating Modes ....................................................................... 61
3.1 3.2 Operating Mode Selection .................................................................................................. 61 Register Descriptions.......................................................................................................... 62 3.2.1 Mode Control Register (MDCR) ........................................................................ 62 3.2.2 System Control Register (SYSCR)..................................................................... 64 Operating Mode Descriptions ............................................................................................. 66 3.3.1 Mode 4................................................................................................................ 66 3.3.2 Mode 5................................................................................................................ 66 3.3.3 Pin Functions ...................................................................................................... 67 Address Map....................................................................................................................... 68 3.4.1 Address Map (Advanced Mode)......................................................................... 68
3.3
3.4
Section 4 Exception Handling ............................................................................. 69
4.1 4.2 4.3 Exception Handling Types and Priority.............................................................................. 69 Exception Sources and Exception Handling Vector Table ................................................. 70 Reset ................................................................................................................................... 72 4.3.1 Reset Exception Handling .................................................................................. 72 4.3.2 Interrupts after Reset........................................................................................... 73 4.3.3 On-Chip Peripheral Functions after Reset Release............................................. 73 Traces Exception Handling................................................................................................. 75 Address Error...................................................................................................................... 76 4.5.1 Address Error Source.......................................................................................... 76
4.4 4.5
Rev.2.00 Jun. 28, 2007 Page x of xxii
4.6
4.7
4.8 4.9
4.5.2 Address Error Exception Handling ..................................................................... 77 Interrupts............................................................................................................................. 78 4.6.1 Interrupt Sources................................................................................................. 78 4.6.2 Interrupt Exception Handling ............................................................................. 78 Instruction Exception Handling .......................................................................................... 79 4.7.1 Trap Instruction Exception Handling.................................................................. 79 4.7.2 Sleep Instruction Exception Handling ................................................................ 80 4.7.3 Exception Handling by Illegal Instruction .......................................................... 81 Stack Status after Exception Handling................................................................................ 82 Usage Note.......................................................................................................................... 83
Section 5 Interrupt Controller ..............................................................................85
5.1 5.2 5.3 Features............................................................................................................................... 85 Input/Output Pins................................................................................................................ 87 Register Descriptions.......................................................................................................... 87 5.3.1 Interrupt Control Register (INTCR) ................................................................... 88 5.3.2 CPU Priority Control Register (CPUPCR) ......................................................... 89 5.3.3 Interrupt Priority Registers A to C, E to H, K, and L (IPRA to IPRC, IPRE to IPRH, IPRK, and IPRL).............................................. 90 5.3.4 IRQ Enable Register (IER) ................................................................................. 92 5.3.5 IRQ Sense Control Registers H and L (ISCRH, ISCRL).................................... 94 5.3.6 IRQ Status Register (ISR)................................................................................... 98 5.3.7 Software Standby Release IRQ Enable Register (SSIER) .................................. 99 Interrupt Sources............................................................................................................... 100 5.4.1 External Interrupts ............................................................................................ 100 5.4.2 Internal Interrupts ............................................................................................. 101 Interrupt Exception Handling Vector Table...................................................................... 102 Interrupt Control Modes and Interrupt Operation ............................................................. 106 5.6.1 Interrupt Control Mode 0 .................................................................................. 106 5.6.2 Interrupt Control Mode 2 .................................................................................. 108 5.6.3 Interrupt Exception Handling Sequence ........................................................... 110 5.6.4 Interrupt Response Times ................................................................................. 111 5.6.5 DTC Activation by Interrupt............................................................................. 112 CPU Priority Control Function Over DTC ....................................................................... 115 Usage Notes ...................................................................................................................... 117 5.8.1 Conflict between Interrupt Generation and Disabling ...................................... 117 5.8.2 Instructions that Disable Interrupts ................................................................... 118 5.8.3 Times when Interrupts are Disabled ................................................................. 118 5.8.4 Interrupts during Execution of EEPMOV Instruction....................................... 118 5.8.5 Interrupts during Execution of MOVMD and MOVSD Instructions................ 118
Rev.2.00 Jun. 28, 2007 Page xi of xxii
5.4
5.5 5.6
5.7 5.8
5.8.6
Interrupts Source Flag of Peripheral Modules .................................................. 119
Section 6 Bus Controller (BSC) ........................................................................ 121
6.1 6.2 Features............................................................................................................................. 121 Register Descriptions........................................................................................................ 124 6.2.1 Bus Width Control Register (ABWCR)............................................................ 124 6.2.2 Access State Control Register (ASTCR) .......................................................... 126 6.2.3 Wait Control Registers A and B (WTCRA, WTCRB) ..................................... 127 6.2.4 Read Strobe Timing Control Register (RDNCR) ............................................. 132 6.2.5 CS Assertion Period Control Registers (CSACR) ............................................ 133 6.2.6 Idle Control Register (IDLCR) ......................................................................... 135 6.2.7 Bus Control Register 1 (BCR1) ........................................................................ 137 6.2.8 Bus Control Register 2 (BCR2) ........................................................................ 139 6.2.9 Endian Control Register (ENDIANCR) ........................................................... 140 6.2.10 SRAM Mode Control Register (SRAMCR) ..................................................... 141 6.2.11 Burst ROM Interface Control Register (BROMCR) ........................................ 142 6.2.12 Address/Data Multiplexed I/O Control Register (MPXCR) ............................. 144 Bus Configuration............................................................................................................. 145 Multi-Clock Function and Number of Access Cycles ...................................................... 146 External Bus ..................................................................................................................... 150 6.5.1 Input/Output Pins.............................................................................................. 150 6.5.2 Area Division.................................................................................................... 153 6.5.3 Chip Select Signals ........................................................................................... 154 6.5.4 External Bus Interface ...................................................................................... 155 6.5.5 Area and External Bus Interface ....................................................................... 159 6.5.6 Endian and Data Alignment.............................................................................. 163 Basic Bus Interface ........................................................................................................... 167 6.6.1 Data Bus ........................................................................................................... 167 6.6.2 I/O Pins Used for Basic Bus Interface .............................................................. 167 6.6.3 Basic Timing..................................................................................................... 168 6.6.4 Wait Control ..................................................................................................... 174 6.6.5 Read Strobe (RD) Timing................................................................................. 176 6.6.6 Extension of Chip Select (CS) Assertion Period............................................... 177 Byte Control SRAM Interface .......................................................................................... 179 6.7.1 Byte Control SRAM Space Setting................................................................... 179 6.7.2 Data Bus ........................................................................................................... 179 6.7.3 I/O Pins Used for Byte Control SRAM Interface ............................................. 180 6.7.4 Basic Timing..................................................................................................... 181 6.7.5 Wait Control ..................................................................................................... 183 6.7.6 Read Strobe (RD) ............................................................................................. 185
6.3 6.4 6.5
6.6
6.7
Rev.2.00 Jun. 28, 2007 Page xii of xxii
6.8
6.9
6.10
6.11
6.12 6.13
6.14
6.15 6.16
6.7.7 Extension of Chip Select (CS) Assertion Period............................................... 185 Burst ROM Interface ........................................................................................................ 185 6.8.1 Burst ROM Space Setting................................................................................. 185 6.8.2 Data Bus............................................................................................................ 186 6.8.3 I/O Pins Used for Burst ROM Interface............................................................ 186 6.8.4 Basic Timing..................................................................................................... 187 6.8.5 Wait Control ..................................................................................................... 189 6.8.6 Read Strobe (RD) Timing................................................................................. 189 6.8.7 Extension of Chip Select (CS) Assertion Period............................................... 189 Address/Data Multiplexed I/O Interface........................................................................... 189 6.9.1 Address/Data Multiplexed I/O Space Setting ................................................... 189 6.9.2 Address/Data Multiplex .................................................................................... 190 6.9.3 Data Bus............................................................................................................ 190 6.9.4 I/O Pins Used for Address/Data Multiplexed I/O Interface .............................. 191 6.9.5 Basic Timing..................................................................................................... 192 6.9.6 Address Cycle Control...................................................................................... 194 6.9.7 Wait Control ..................................................................................................... 195 6.9.8 Read Strobe (RD) Timing................................................................................. 195 6.9.9 Extension of Chip Select (CS) Assertion Period............................................... 196 Idle Cycle.......................................................................................................................... 198 6.10.1 Operation .......................................................................................................... 198 6.10.2 Pin States in Idle Cycle ..................................................................................... 206 Bus Release....................................................................................................................... 207 6.11.1 Operation .......................................................................................................... 207 6.11.2 Pin States in External Bus Released State......................................................... 208 6.11.3 Transition Timing ............................................................................................. 209 Internal Bus....................................................................................................................... 210 6.12.1 Access to Internal Address Space ..................................................................... 210 Write Data Buffer Function .............................................................................................. 211 6.13.1 Write Data Buffer Function for External Data Bus........................................... 211 6.13.2 Write Data Buffer Function for Peripheral Modules ........................................ 212 Bus Arbitration ................................................................................................................. 213 6.14.1 Operation .......................................................................................................... 213 6.14.2 Bus Transfer Timing ......................................................................................... 214 Bus Controller Operation in Reset .................................................................................... 215 Usage Notes ...................................................................................................................... 215
Section 7 Data Transfer Controller (DTC) ........................................................217
7.1 7.2 Features............................................................................................................................. 217 Register Descriptions........................................................................................................ 219
Rev.2.00 Jun. 28, 2007 Page xiii of xxii
7.3 7.4 7.5
7.6 7.7
7.8 7.9
7.2.1 DTC Mode Register A (MRA) ......................................................................... 220 7.2.2 DTC Mode Register B (MRB).......................................................................... 221 7.2.3 DTC Source Address Register (SAR)............................................................... 223 7.2.4 DTC Destination Address Register (DAR)....................................................... 223 7.2.5 DTC Transfer Count Register A (CRA) ........................................................... 224 7.2.6 DTC Transfer Count Register B (CRB)............................................................ 224 7.2.7 DTC Enable Registers A to H (DTCERA to DTCERH) .................................. 225 7.2.8 DTC Control Register (DTCCR) ...................................................................... 226 7.2.9 DTC Vector Base Register (DTCVBR)............................................................ 227 Activation Sources............................................................................................................ 227 Location of Transfer Information and DTC Vector Table................................................ 228 Operation .......................................................................................................................... 231 7.5.1 Bus Cycle Division ........................................................................................... 233 7.5.2 Transfer Information Read Skip Function ........................................................ 235 7.5.3 Transfer Information Writeback Skip Function................................................ 236 7.5.4 Normal Transfer Mode ..................................................................................... 236 7.5.5 Repeat Transfer Mode ...................................................................................... 237 7.5.6 Block Transfer Mode ........................................................................................ 239 7.5.7 Chain Transfer .................................................................................................. 240 7.5.8 Operation Timing.............................................................................................. 241 7.5.9 Number of DTC Execution Cycles ................................................................... 243 7.5.10 DTC Bus Release Timing ................................................................................. 244 7.5.11 DTC Priority Level Control to the CPU ........................................................... 244 DTC Activation by Interrupt............................................................................................. 245 Examples of Use of the DTC............................................................................................ 246 7.7.1 Normal Transfer Mode ..................................................................................... 246 7.7.2 Chain Transfer .................................................................................................. 247 7.7.3 Chain Transfer when Counter = 0..................................................................... 248 Interrupt Sources............................................................................................................... 249 Usage Notes ...................................................................................................................... 249 7.9.1 Module Stop State Setting ................................................................................ 249 7.9.2 On-Chip RAM .................................................................................................. 250 7.9.3 DTCE Bit Setting.............................................................................................. 250 7.9.4 Chain Transfer .................................................................................................. 250 7.9.5 Transfer Information Start Address, Source Address, and Destination Address ................................................................................... 250 7.9.6 Endian............................................................................................................... 250
Section 8 I/O Ports............................................................................................. 251
8.1 Register Descriptions........................................................................................................ 257
Rev.2.00 Jun. 28, 2007 Page xiv of xxii
8.2
8.3
8.4
Data Direction Register (PnDDR) (n = 1 to 3, 6, A, B, D to F, H, and I) ......... 258 Data Register (PnDR) (n = 1 to 3, 6, A, B, D to F, H, and I)............................ 259 Port Register (PORTn) (n = 1 to 3, 5, 6, A, B, D to F, H, and I) ...................... 259 Input Buffer Control Register (PnICR) (n = 1 to 3, 5, 6, A, B, D to F, H, and I)............................................................ 260 8.1.5 Pull-Up MOS Control Register (PnPCR) (n = D to F, H, and I)....................... 261 8.1.6 Open-Drain Control Register (PnODR) (n = 2 and F) ...................................... 262 Output Buffer Control....................................................................................................... 262 8.2.1 Port 1................................................................................................................. 262 8.2.2 Port 2................................................................................................................. 265 8.2.3 Port 3................................................................................................................. 269 8.2.4 Port 5................................................................................................................. 273 8.2.5 Port 6................................................................................................................. 274 8.2.6 Port A................................................................................................................ 276 8.2.7 Port B ................................................................................................................ 280 8.2.8 Port D................................................................................................................ 282 8.2.9 Port E ................................................................................................................ 282 8.2.10 Port F ................................................................................................................ 283 8.2.11 Port H................................................................................................................ 286 8.2.12 Port I ................................................................................................................. 286 Port Function Controller ................................................................................................... 292 8.3.1 Port Function Control Register 0 (PFCR0)....................................................... 292 8.3.2 Port Function Control Register 1 (PFCR1)....................................................... 293 8.3.3 Port Function Control Register 2 (PFCR2)....................................................... 294 8.3.4 Port Function Control Register 4 (PFCR4)....................................................... 296 8.3.5 Port Function Control Register 6 (PFCR6)....................................................... 297 8.3.6 Port Function Control Register 9 (PFCR9)....................................................... 298 8.3.7 Port Function Control Register B (PFCRB)...................................................... 300 8.3.8 Port Function Control Register C (PFCRC)...................................................... 301 Usage Notes ...................................................................................................................... 303 8.4.1 Notes on Input Buffer Control Register (ICR) Setting ..................................... 303 8.4.2 Notes on Port Function Control Register (PFCR) Settings............................... 303
8.1.1 8.1.2 8.1.3 8.1.4
Section 9 16-Bit Timer Pulse Unit (TPU) .........................................................305
9.1 9.2 9.3 Features............................................................................................................................. 305 Input/Output Pins.............................................................................................................. 309 Register Descriptions........................................................................................................ 310 9.3.1 Timer Control Register (TCR).......................................................................... 312 9.3.2 Timer Mode Register (TMDR) ......................................................................... 318 9.3.3 Timer I/O Control Register (TIOR) .................................................................. 319
Rev.2.00 Jun. 28, 2007 Page xv of xxii
9.4
9.5 9.6 9.7 9.8
9.9
9.3.4 Timer Interrupt Enable Register (TIER)........................................................... 337 9.3.5 Timer Status Register (TSR)............................................................................. 339 9.3.6 Timer Counter (TCNT)..................................................................................... 343 9.3.7 Timer General Register (TGR) ......................................................................... 343 9.3.8 Timer Start Register (TSTR) ............................................................................ 344 9.3.9 Timer Synchronous Register (TSYR)............................................................... 345 Operation .......................................................................................................................... 346 9.4.1 Basic Functions................................................................................................. 346 9.4.2 Synchronous Operation..................................................................................... 352 9.4.3 Buffer Operation............................................................................................... 354 9.4.4 Cascaded Operation .......................................................................................... 357 9.4.5 PWM Modes..................................................................................................... 359 9.4.6 Phase Counting Mode....................................................................................... 364 Interrupt Sources............................................................................................................... 370 DTC Activation ................................................................................................................ 372 A/D Converter Activation................................................................................................. 372 Operation Timing.............................................................................................................. 373 9.8.1 Input/Output Timing ......................................................................................... 373 9.8.2 Interrupt Signal Timing .................................................................................... 377 Usage Notes ...................................................................................................................... 381 9.9.1 Module Stop State Setting ................................................................................ 381 9.9.2 Input Clock Restrictions ................................................................................... 381 9.9.3 Caution on Cycle Setting .................................................................................. 382 9.9.4 Conflict between TCNT Write and Clear Operations....................................... 382 9.9.5 Conflict between TCNT Write and Increment Operations ............................... 383 9.9.6 Conflict between TGR Write and Compare Match........................................... 383 9.9.7 Conflict between Buffer Register Write and Compare Match .......................... 384 9.9.8 Conflict between TGR Read and Input Capture ............................................... 384 9.9.9 Conflict between TGR Write and Input Capture .............................................. 385 9.9.10 Conflict between Buffer Register Write and Input Capture.............................. 386 9.9.11 Conflict between Overflow/Underflow and Counter Clearing ......................... 387 9.9.12 Conflict between TCNT Write and Overflow/Underflow ................................ 387 9.9.13 Multiplexing of I/O Pins ................................................................................... 388 9.9.14 Interrupts and Module Stop State ..................................................................... 388
Section 10 Programmable Pulse Generator (PPG)............................................ 389
10.1 10.2 10.3 Features............................................................................................................................. 389 Input/Output Pins.............................................................................................................. 391 Register Descriptions........................................................................................................ 392 10.3.1 Next Data Enable Registers H, L (NDERH, NDERL) ..................................... 392
Rev.2.00 Jun. 28, 2007 Page xvi of xxii
10.4
10.5
10.3.2 Output Data Registers H, L (PODRH, PODRL)............................................... 394 10.3.3 Next Data Registers H, L (NDRH, NDRL) ...................................................... 395 10.3.4 PPG Output Control Register (PCR) ................................................................ 398 10.3.5 PPG Output Mode Register (PMR) .................................................................. 399 Operation .......................................................................................................................... 401 10.4.1 Output Timing................................................................................................... 401 10.4.2 Sample Setup Procedure for Normal Pulse Output........................................... 402 10.4.3 Example of Normal Pulse Output (Example of 5-Phase Pulse Output)............ 403 10.4.4 Non-Overlapping Pulse Output......................................................................... 404 10.4.5 Sample Setup Procedure for Non-Overlapping Pulse Output ........................... 406 10.4.6 Example of Non-Overlapping Pulse Output (Example of 4-Phase Complementary Non-Overlapping Pulse Output) .......... 407 10.4.7 Inverted Pulse Output ....................................................................................... 409 10.4.8 Pulse Output Triggered by Input Capture ......................................................... 410 Usage Notes ...................................................................................................................... 410 10.5.1 Module Stop State Setting ................................................................................ 410 10.5.2 Operation of Pulse Output Pins......................................................................... 410
Section 11 8-Bit Timers (TMR).........................................................................411
11.1 11.2 11.3 Features............................................................................................................................. 411 Input/Output Pins.............................................................................................................. 414 Register Descriptions........................................................................................................ 415 11.3.1 Timer Counter (TCNT)..................................................................................... 416 11.3.2 Time Constant Register A (TCORA)................................................................ 416 11.3.3 Time Constant Register B (TCORB) ................................................................ 417 11.3.4 Timer Control Register (TCR).......................................................................... 417 11.3.5 Timer Counter Control Register (TCCR) ......................................................... 419 11.3.6 Timer Control/Status Register (TCSR)............................................................. 421 Operation .......................................................................................................................... 425 11.4.1 Pulse Output...................................................................................................... 425 11.4.2 Reset Input ........................................................................................................ 426 Operation Timing.............................................................................................................. 427 11.5.1 TCNT Count Timing ........................................................................................ 427 11.5.2 Timing of CMFA and CMFB Setting at Compare Match................................. 427 11.5.3 Timing of Timer Output at Compare Match ..................................................... 428 11.5.4 Timing of Counter Clear by Compare Match ................................................... 428 11.5.5 Timing of TCNT External Reset....................................................................... 429 11.5.6 Timing of Overflow Flag (OVF) Setting .......................................................... 429 Operation with Cascaded Connection............................................................................... 430 11.6.1 16-Bit Counter Mode ........................................................................................ 430
Rev.2.00 Jun. 28, 2007 Page xvii of xxii
11.4
11.5
11.6
11.7
11.8
11.6.2 Compare Match Count Mode............................................................................ 430 Interrupt Sources............................................................................................................... 431 11.7.1 Interrupt Sources and DTC Activation ............................................................. 431 11.7.2 A/D Converter Activation................................................................................. 431 Usage Notes ...................................................................................................................... 432 11.8.1 Notes on Setting Cycle ..................................................................................... 432 11.8.2 Conflict between TCNT Write and Clear ......................................................... 432 11.8.3 Conflict between TCNT Write and Increment.................................................. 433 11.8.4 Conflict between TCOR Write and Compare Match........................................ 433 11.8.5 Conflict between Compare Matches A and B................................................... 434 11.8.6 Switching of Internal Clocks and TCNT Operation ......................................... 434 11.8.7 Mode Setting with Cascaded Connection ......................................................... 436 11.8.8 Module Stop State Setting ................................................................................ 436 11.8.9 Interrupts in Module Stop State ........................................................................ 436
Section 12 Watchdog Timer (WDT) ................................................................. 437
12.1 12.2 12.3 Features............................................................................................................................. 437 Input/Output Pin ............................................................................................................... 438 Register Descriptions........................................................................................................ 438 12.3.1 Timer Counter (TCNT)..................................................................................... 438 12.3.2 Timer Control/Status Register (TCSR)............................................................. 439 12.3.3 Reset Control/Status Register (RSTCSR)......................................................... 441 Operation .......................................................................................................................... 442 12.4.1 Watchdog Timer Mode..................................................................................... 442 12.4.2 Interval Timer Mode......................................................................................... 444 Interrupt Source ................................................................................................................ 444 Usage Notes ...................................................................................................................... 445 12.6.1 Notes on Register Access ................................................................................. 445 12.6.2 Conflict between Timer Counter (TCNT) Write and Increment....................... 446 12.6.3 Changing Values of Bits CKS2 to CKS0.......................................................... 446 12.6.4 Switching between Watchdog Timer Mode and Interval Timer Mode............. 446 12.6.5 Internal Reset in Watchdog Timer Mode.......................................................... 447 12.6.6 System Reset by WDTOVF Signal................................................................... 447 12.6.7 Transition to Watchdog Timer Mode or Software Standby Mode.................... 447
12.4
12.5 12.6
Section 13 Serial Communication Interface (SCI)............................................ 449
13.1 13.2 13.3 Features............................................................................................................................. 449 Input/Output Pins.............................................................................................................. 451 Register Descriptions........................................................................................................ 452 13.3.1 Receive Shift Register (RSR) ........................................................................... 454
Rev.2.00 Jun. 28, 2007 Page xviii of xxii
13.4
13.5
13.6
13.7
13.8
13.3.2 Receive Data Register (RDR) ........................................................................... 454 13.3.3 Transmit Data Register (TDR).......................................................................... 454 13.3.4 Transmit Shift Register (TSR) .......................................................................... 455 13.3.5 Serial Mode Register (SMR) ............................................................................ 455 13.3.6 Serial Control Register (SCR)........................................................................... 458 13.3.7 Serial Status Register (SSR) ............................................................................. 463 13.3.8 Smart Card Mode Register (SCMR)................................................................. 470 13.3.9 Bit Rate Register (BRR) ................................................................................... 471 13.3.10 Serial Extended Mode Register (SEMR) .......................................................... 479 Operation in Asynchronous Mode .................................................................................... 481 13.4.1 Data Transfer Format........................................................................................ 482 13.4.2 Receive Data Sampling Timing and Reception Margin in Asynchronous Mode................................................. 483 13.4.3 Clock................................................................................................................. 484 13.4.4 SCI Initialization (Asynchronous Mode) .......................................................... 485 13.4.5 Serial Data Transmission (Asynchronous Mode) ............................................. 486 13.4.6 Serial Data Reception (Asynchronous Mode)................................................... 488 Multiprocessor Communication Function......................................................................... 492 13.5.1 Multiprocessor Serial Data Transmission ......................................................... 494 13.5.2 Multiprocessor Serial Data Reception .............................................................. 495 Operation in Clocked Synchronous Mode ........................................................................ 498 13.6.1 Clock................................................................................................................. 498 13.6.2 SCI Initialization (Clocked Synchronous Mode) .............................................. 499 13.6.3 Serial Data Transmission (Clocked Synchronous Mode) ................................. 500 13.6.4 Serial Data Reception (Clocked Synchronous Mode)....................................... 502 13.6.5 Simultaneous Serial Data Transmission and Reception (Clocked Synchronous Mode) .......................................................................... 504 Operation in Smart Card Interface Mode.......................................................................... 506 13.7.1 Sample Connection ........................................................................................... 506 13.7.2 Data Format (Except in Block Transfer Mode) ................................................ 507 13.7.3 Block Transfer Mode ........................................................................................ 508 13.7.4 Receive Data Sampling Timing and Reception Margin.................................... 509 13.7.5 Initialization ...................................................................................................... 510 13.7.6 Data Transmission (Except in Block Transfer Mode) ...................................... 511 13.7.7 Serial Data Reception (Except in Block Transfer Mode).................................. 514 13.7.8 Clock Output Control........................................................................................ 515 Interrupt Sources............................................................................................................... 517 13.8.1 Interrupts in Normal Serial Communication Interface Mode ........................... 517 13.8.2 Interrupts in Smart Card Interface Mode .......................................................... 518
Rev.2.00 Jun. 28, 2007 Page xix of xxii
13.9
Usage Notes ...................................................................................................................... 519 13.9.1 Module Stop State Setting ................................................................................ 519 13.9.2 Break Detection and Processing ....................................................................... 519 13.9.3 Mark State and Break Detection ....................................................................... 519 13.9.4 Receive Error Flags and Transmit Operations (Clocked Synchronous Mode Only) ................................................................. 519 13.9.5 Relation between Writing to TDR and TDRE Flag .......................................... 520 13.9.6 Restrictions on Using DTC............................................................................... 520 13.9.7 SCI Operations during Power-Down State ....................................................... 521
Section 14 A/D Converter ................................................................................. 525
14.1 14.2 14.3 Features............................................................................................................................. 525 Input/Output Pins.............................................................................................................. 527 Register Descriptions........................................................................................................ 527 14.3.1 A/D Data Registers A to H (ADDRA to ADDRH) .......................................... 528 14.3.2 A/D Control/Status Register (ADCSR) ............................................................ 529 14.3.3 A/D Control Register (ADCR) ......................................................................... 531 Operation .......................................................................................................................... 532 14.4.1 Single Mode...................................................................................................... 532 14.4.2 Scan Mode ........................................................................................................ 533 14.4.3 Input Sampling and A/D Conversion Time ...................................................... 535 14.4.4 External Trigger Input Timing.......................................................................... 537 Interrupt Source ................................................................................................................ 537 A/D Conversion Accuracy Definitions ............................................................................. 538 Usage Notes ...................................................................................................................... 540 14.7.1 Module Stop State Setting ................................................................................ 540 14.7.2 Permissible Signal Source Impedance .............................................................. 540 14.7.3 Influences on Absolute Accuracy ..................................................................... 541 14.7.4 Setting Range of Analog Power Supply and Other Pins................................... 541 14.7.5 Notes on Board Design ..................................................................................... 541 14.7.6 Notes on Noise Countermeasures ..................................................................... 542 14.7.7 A/D Input Hold Function in Software Standby Mode ...................................... 543
14.4
14.5 14.6 14.7
Section 15 D/A Converter ................................................................................. 545
15.1 15.2 15.3 Features............................................................................................................................. 545 Input/Output Pins.............................................................................................................. 546 Register Descriptions........................................................................................................ 546 15.3.1 D/A Data Registers 0 and 1 (DADR0 and DADR1)......................................... 546 15.3.2 D/A Control Register 01 (DACR01) ................................................................ 547 Operation .......................................................................................................................... 549
15.4
Rev.2.00 Jun. 28, 2007 Page xx of xxii
15.5
Usage Notes ...................................................................................................................... 550 15.5.1 Module Stop State Setting ................................................................................ 550 15.5.2 D/A Output Hold Function in Software Standby Mode.................................... 550
Section 16 RAM ................................................................................................551 Section 17 Clock Pulse Generator .....................................................................553
17.1 17.2 Register Description ......................................................................................................... 554 17.1.1 System Clock Control Register (SCKCR) ........................................................ 554 Oscillator........................................................................................................................... 557 17.2.1 Connecting Crystal Resonator .......................................................................... 557 17.2.2 External Clock Input ......................................................................................... 558 PLL Circuit ....................................................................................................................... 558 Frequency Divider ............................................................................................................ 558 Usage Notes ...................................................................................................................... 559 17.5.1 Notes on Clock Pulse Generator ....................................................................... 559 17.5.2 Notes on Resonator ........................................................................................... 560 17.5.3 Notes on Board Design ..................................................................................... 560
17.3 17.4 17.5
Section 18 Power-Down States..........................................................................563
18.1 18.2 Features............................................................................................................................. 563 Register Descriptions........................................................................................................ 565 18.2.1 Standby Control Register (SBYCR) ................................................................. 566 18.2.2 Module Stop Control Registers A and B (MSTPCRA and MSTPCRB) .......... 569 18.2.3 Module Stop Control Register C (MSTPCRC)................................................. 572 Multi-Clock Function ....................................................................................................... 573 Module Stop Function ...................................................................................................... 573 Sleep Mode ....................................................................................................................... 574 18.5.1 Transition to Sleep Mode.................................................................................. 574 18.5.2 Clearing Sleep Mode......................................................................................... 574 All-Module-Clock-Stop Mode.......................................................................................... 575 Software Standby Mode.................................................................................................... 575 18.7.1 Transition to Software Standby Mode .............................................................. 575 18.7.2 Clearing Software Standby Mode ..................................................................... 576 18.7.3 Setting Oscillation Settling Time after Clearing Software Standby Mode ....... 576 18.7.4 Software Standby Mode Application Example................................................. 579 Hardware Standby Mode .................................................................................................. 580 18.8.1 Transition to Hardware Standby Mode ............................................................. 580 18.8.2 Clearing Hardware Standby Mode.................................................................... 580 18.8.3 Hardware Standby Mode Timing...................................................................... 580
Rev.2.00 Jun. 28, 2007 Page xxi of xxii
18.3 18.4 18.5
18.6 18.7
18.8
18.8.4 Timing Sequence at Power-On ......................................................................... 581 18.9 Sleep Instruction Exception Handling .............................................................................. 582 18.10 B Clock Output Control.................................................................................................. 585 18.11 Usage Notes ...................................................................................................................... 586 18.11.1 I/O Port Status................................................................................................... 586 18.11.2 Current Consumption during Oscillation Settling Standby Period ................... 586 18.11.3 DTC Module Stop............................................................................................. 586 18.11.4 On-Chip Peripheral Module Interrupts ............................................................. 586 18.11.5 Writing to MSTPCRA, MSTPCRB, and MSTPCRC....................................... 586
Section 19 List of Registers............................................................................... 587
19.1 19.2 19.3 Register Addresses (Address Order)................................................................................. 588 Register Bits ..................................................................................................................... 597 Register States in Each Operating Mode .......................................................................... 607
Section 20 Electrical Characteristics ................................................................. 617
20.1 20.2 20.3 Absolute Maximum Ratings ............................................................................................. 617 DC Characteristics ............................................................................................................ 618 AC Characteristics ............................................................................................................ 621 20.3.1 Clock Timing .................................................................................................... 622 20.3.2 Control Signal Timing ...................................................................................... 624 20.3.3 Bus Timing ....................................................................................................... 625 20.3.4 Timing of On-Chip Peripheral Modules ........................................................... 640 A/D Conversion Characteristics ....................................................................................... 644 D/A Conversion Characteristics ....................................................................................... 645
20.4 20.5
Appendix ............................................................................................................. 647
A. B. C. D. Port States in Each Pin State............................................................................................. 647 Product Lineup.................................................................................................................. 650 Package Dimensions ......................................................................................................... 651 Treatment of Unused Pins................................................................................................. 652
Main Revisions and Additions in this Edition..................................................... 655 Index ................................................................................................................... 661
Rev.2.00 Jun. 28, 2007 Page xxii of xxii
Section 1 Overview
Section 1 Overview
1.1 Features
The core of each product in the H8SX/1650 Group of CISC (complex instruction set computer) microcomputers is an H8SX CPU, which has an internal 32-bit architecture. The H8SX CPU provides upward-compatibility with the CPUs of other Renesas Technology-original microcomputers; H8/300, H8/300H, and H8S. As peripheral functions, each LSI of the Group includes a bus-state controller that enables direct connection to different kinds of memory. The LSI of the Group also includes serial communication interfaces, A/D and D/A converters, and a multi-function timer that makes motor control easy. Together, the modules realize low-cost configurations for end systems. The power consumption of these modules are kept down dynamically by an on-chip power-management function. 1.1.1 Applications
Examples of the applications of this LSI include PC peripheral equipment, optical storage devices, office automation equipment, and industrial equipment. Notes: The following additions and changes have been made in the switch from the H8SX/1650A to the H8SX/1650C. * The chip select signal is added to PF7, PF6, and PF5.
Rev.2.00 Jun. 28, 2007 Page 1 of 666 REJ09B0311-0200
Section 1 Overview
1.1.2
Overview of Functions
Table 1.1 lists the functions of H8SX/1650 Group products in outline. Table 1.1 Overview of Functions
Module/ Function RAM CPU CPU Description * * * ROM lineup: ROMless versions only RAM capacity: 24 Kbytes 32-bit high-speed H8SX CPU (CISC type) Upward compatibility for H8/300, H8/300H, and H8S CPUs at object level * * * Sixteen 16-bit general registers Eleven addressing modes 4-Gbyte address space Program: 4 Gbytes available Data: 4 Gbytes available * 87 basic instructions, classifiable as bit arithmetic and logic instructions, multiply and divide instructions, bit manipulation instructions, multiply-and-accumulate instructions, and others Minimum instruction execution time: 20.0 ns (for an ADD instruction while system clock I = 50 MHz and VCC = 3.0 to 3.6 V) On-chip multiplier (16 x 16 32 bits) Supports multiply-and-accumulate instructions (16 x 16 + 32 32 bits) Advanced mode
Classification Memory
*
* * Operating mode MCU operating mode *
Mode 4: On-chip ROM disabled external extended mode, 16-bit bus (selected by driving the MD0 pin low) Mode 5: On-chip ROM disabled external extended mode, 8-bit bus (selected by driving the MD0 pin high) * Low power consumption state (transition driven by the SLEEP instruction)
Rev.2.00 Jun. 28, 2007 Page 2 of 666 REJ09B0311-0200
Section 1 Overview
Classification Interrupt (source)
Module/ Function Interrupt controller (INTC)
Description * * * * * Thirteen external interrupt pins (NMI, and IRQ11 to IRQ0) 56 internal interrupt sources Two interrupt control modes (specified by the interrupt control register) Eight priority orders specifiable (by setting the interrupt priority register) Independent vector addresses Allows DMA transfer over 45 channels (number of DTC activation sources) Activated by interrupt sources (chain transfer enabled) Three transfer modes (normal transfer, repeat transfer, block transfer) Short-address mode or full-address mode selectable 16-Mbyte external address space The external address space can be divided into eight areas, each of which is independently controllable Chip-select signals (CS0 to CA7) can be output Access in two or three states can be selected for each area Program wait cycles can be inserted The period of CS assertion can be extended Idle cycles can be inserted * Bus arbitration function (arbitrates bus mastership among the internal CPU and DTC, and external bus masters)
DMA
Data transfer controller (DTC)
* * * *
External bus extension
Bus controller (BSC)
* *
Rev.2.00 Jun. 28, 2007 Page 3 of 666 REJ09B0311-0200
Section 1 Overview
Classification External bus extension
Module/ Function Bus controller (BSC)
Description Bus formats * * * External memory interfaces (for the connection of ROM, burst ROM, SRAM, and byte control SRAM) Address/data bus format: Support for both separate and multiplexed buses (8-bit access or 16-bit access) Endian conversion function for connecting devices in littleendian format One clock generation circuit available Separate clock signals are provided for each of functional modules (detailed below) and each is independently specifiable (multi-clock function) System-intended data transfer modules, i.e. the CPU, runs in synchronization with the system clock (I): 8 to 50 MHz Internal peripheral functions run in synchronization with the peripheral module clock (P): 8 to 35 MHz Modules in the external space are supplied with the external bus clock (B): 8 to 50 MHz * * Includes a PLL frequency multiplication circuit and frequency divider, so the operating frequency is selectable Five low-power-consumption modes: Sleep mode, module-stop mode, all-module-clock-stop mode, software standby mode, and hardware standby mode 10-bit resolution x eight input channels Sample and hold function included Conversion time: 7.4 s per channel (with peripheral module clock (P) at 35-MHz operation) Two operating modes: single mode and scan mode Three ways to start A/D conversion: software, timer (TPU/TMR) trigger, and external trigger
Clock
Clock pulse * generator * (CPG)
A/D converter
A/D converter (ADC)
* * * * *
Rev.2.00 Jun. 28, 2007 Page 4 of 666 REJ09B0311-0200
Section 1 Overview
Classification D/A converter
Module/ Function D/A converter (DAC) 8-bit timer (TMR)
Description * * * * * 8-bit resolution x two output channels Output voltage: 0 V to Vref, maximum conversion time: 10 s (with 20-pF load) 8 bits x four channels (can be used as 16 bits x two channels) Select from among seven clock sources (six internal clocks and one external clock) Allows the output of pulse trains with a desired duty cycle or PWM signals 16 bits x six channels (general pulse timer unit) Select from among eight counter-input clocks for each channel Up to 16 pulse inputs and outputs Counter clear operation, simultaneous writing to multiple timer counters (TCNT), simultaneous clearing by compare match and input capture possible, simultaneous input/output for registers possible by counter synchronous operation, and up to 15-phase PWM output possible by combination with synchronous operation Buffered operation, cascaded operation (32 bits x two channels), and phase counting mode (two-phase encoder input) settable for each channel Input capture function supported Output compare function (by the output of compare match waveform) supported 16-bit pulse output Four output groups, non-overlapping mode, and inverted output can be set Selectable output trigger signals; the PPG can operate in conjunction with the data transfer controller (DTC) 8 bits x one channel (selectable from eight counter input clocks) Switchable between watchdog timer mode and interval timer mode
Timer
16-bit timer * pulse unit * (TPU) * *
* * * * Programmable pulse * generator (PPG) * Watchdog timer Watchdog timer (WDT) * *
Rev.2.00 Jun. 28, 2007 Page 5 of 666 REJ09B0311-0200
Section 1 Overview
Classification Serial interface
Module/ Function Serial communication interface (SCI)
Description * * * * * * * * * * * Four channels (select asynchronous or clocked synchronous serial communication mode) Full-duplex communication capability Select the desired bit rate and LSB-first or MSB-first transfer The SCI module supports a smart card (SIM) interface. Eight CMOS input-only pins 50 CMOS input/output pins Eight large-current drive pins (port 3) 11 pull-up resistors 11 open drains 120-pin thin QFP package (package code: FP-120B, package dimensions: 14 x 14 mm, pin pitch: 0.40 mm) Lead- (Pb-) free versions available Operating frequency: 8 to 50 MHz Power supply voltage: Vcc = 3.0 to 3.6 V, Avcc = 3.0 to 3.6 V Supply current: 45 mA (typ.) (Vcc = 3.3 V, Avcc = 3.3 V, I = B = 50 MHz, P = 25 MHz)
Smart card/ SIM I/O ports
Package
Operating frequency/ Power supply voltage
* * *
Operating peripheral temperature (C)
* *
-20 to +75C (regular specifications) -40 to +85C (wide-range specifications)
Rev.2.00 Jun. 28, 2007 Page 6 of 666 REJ09B0311-0200
Section 1 Overview
1.2
List of Products
Table 1.2 is the list of products, and figure 1.1 shows how to read the product name code. Table 1.2 List of Products
ROM Capacity RAM Capacity 24 Kbytes Package PLQP0120LA-A (FP-120BV) (as of August, 2005) Remarks ROMless versions only
Product Type No. R5S61650CFPV
Product type no. R
5
S
61650C
FP
V
Indicates the Pb-free version. Indicates the package. FP: LQFP Indicates the product-specific number. H8SX/1650 Group Indicates the type of ROM device. S: External ROM Indicates the product classification Microcomputer R indicates a Renesas semiconductor product.
Figure 1.1 How to Read the Product Name Code
Rev.2.00 Jun. 28, 2007 Page 7 of 666 REJ09B0311-0200
Section 1 Overview
1.3
Block Diagram
WDT
Port 1
Interrupt controller RAM
Port 2 TMR (unit 0) x 2 channels Port 3 TMR (unit 1) x 2 channels Port 5
BSC
Internal peripheral bus Internal system bus
H8SX CPU
TPU x 6 channels
Port 6
PPG
Port A
Port B SCI x 4 channels Port D
DTC
A/D converter
Port E
Clock pulse generator
D/A converter
Port F
Port H
External bus
Port I
[Legend] CPU: Central processing unit DTC: Data transfer controller BSC: Bus controller WDT: Watchdog timer
TMR: TPU: PPG: SCI:
8-bit timer 16-bit timer pulse unit Programmable pulse generator Serial communications interface
Figure 1.2 Block Diagram
Rev.2.00 Jun. 28, 2007 Page 8 of 666 REJ09B0311-0200
Section 1 Overview
1.4
Pin Assignments
P61/TMCI2/RxD4/IRQ9-B P60/TMRI2/TxD4/IRQ8-B STBY P17/IRQ7-A/TCLKD-B P16/IRQ6-A/TCLKC-B Vcc EXTAL XTAL Vss WDTOVF P15/IRQ5-A/TCLKB-B P14/IRQ4-A/TCLKA-B VCL RES Vss P13/ADTRG0/IRQ3-A P12/SCK2/IRQ2-A P11/RxD2/IRQ1-A P10/TxD2/IRQ0-A PI7/D15 PI6/D14 PI5/D13 PI4/D12 Vss PI3/D11 PI2/D10 PI1/D9 PI0/D8 Vcc PH7/D7
PB1/CS1/CS2-B/CS5-A/CS6-B/CS7-B PB2/CS2-A/CS6-A PB3/CS3/CS7-A MD2 PF7/A23/CS4-C/CS5-C/CS6-C/CS7-C PF6/A22/CS6-D PF5/A21/CS5-D PF4/A20 PF3/A19 Vss PF2/A18 PF1/A17 PF0/A16 PE7/A15 PE6/A14 PE5/A13 Vss PE4/A12 Vcc PE3/A11 PE2/A10 PE1/A9 PE0/A8 PD7/A7 PD6/A6 Vss PD5/A5 PD4/A4 PD3/A3 PD2/A2
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
P62/TMO2/SCK4/IRQ10-B PLLVcc P63/TMRI3/IRQ11-B PLLVss P64/TMCI3 P65/TMO3 MD0 P50/AN0/IRQ0-B P51/AN1/IRQ1-B P52/AN2/IRQ2-B AVcc P53/AN3/IRQ3-B AVss P54/AN4/IRQ4-B Vref P55/AN5/IRQ5-B P56/AN6/DA0/IRQ6-B P57/AN7/DA1/IRQ7-B MD1 PA0/BREQO/BS-A PA1/BACK/(RD/WR) PA2/BREQ/WAIT PA3/LLWR/LLB PA4/LHWR/LUB PA5/RD PA6/AS/AH/BS-B Vss PA7/B Vcc PB0/CS0/CS4-A/CS5-B
90 89 88 87 86 85 84 83 82 81 80 79 78 77 76 75 74 73 72 71 70 69 68 67 66 65 64 63 62 61
91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120
H8SX/1650 Group PLQP0120LA-A (FP-120BV) (top view)
60 59 58 57 56 55 54 53 52 51 50 49 48 47 46 45 44 43 42 41 40 39 38 37 36 35 34 33 32 31
PH6/D6 PH5/D5 PH4/D4 Vss PH3/D3 PH2/D2 PH1/D1 PH0/D0 NMI P37/PO15/TIOCA2/TIOCB2/TCLKD-A P36/PO14/TIOCA2 P35/PO13/TIOCA1/TIOCB1/TCLKC-A P34/PO12/TIOCA1 P33/PO11/TIOCC0/TIOCD0/TCLKB-A P32/PO10/TIOCC0/TCLKA-A P31/PO9/TIOCA0/TIOCB0 Vcc P30/PO8/TIOCA0 Vss P27/PO7/TIOCA5/TIOCB5 P26/PO6/TIOCA5/TMO1/TxD1 P25/PO5/TIOCA4/TMCI1/RxD1 P24/PO4/TIOCA4/TIOCB4/TMRI1/SCK1 P23/PO3/TIOCC3/TIOCD3/IRQ11-A P22/PO2/TIOCC3/TMO0/TxD0/IRQ10-A P21/PO1/TIOCA3/TMCI0/RxD0/IRQ9-A P20/PO0/TIOCA3/TIOCB3/TMRI0/SCK0/IRQ8-A EMLE PD0/A0 PD1/A1
Figure 1.3 Pin Assignments
Rev.2.00 Jun. 28, 2007 Page 9 of 666 REJ09B0311-0200
Section 1 Overview
1.5
Table 1.3
Pin Functions
Pin Functions
Pin Name VCC VCL VSS PLLVCC PLLVSS I/O Input Input Output Input Input Input Input Output Input/ output Input Output Description Power supply pins. Connect them to the system power supply. Connect this pin to VSS via a 0.1-uF capacitor (The capacitor should be placed close to the pin). Ground pins. Connect them to the system power supply (0 V). Power supply pin for the PLL circuit. Ground pin for the PLL circuit. Pins for a crystal resonator. An external clock signal can be input through the EXTAL pin. For an example of this connection, see section 17, Clock Pulse Generator. Outputs the system clock for external devices. Pins for setting the operating mode. The signal levels on these pins must not be changed during operation. Reset signal input pin. This LSI enters the reset state when this signal goes low. This LSI enters hardware standby mode when this signal goes low. Input pin for the on-chip emulator enable signal. The signal level should normally be fixed low. Output pins for the address bits. Input and output for the bidirectional data bus. These pins also output addresses when accessing an address-data multiplexed I/O interface space. External bus-master modules assert this signal to request the bus. Internal bus-master modules assert this signal to request access to the external space via the bus in the external bus released state.
Classification Power supply
Clock
XTAL EXTAL B
Operating mode MD2 to MD0 control System control RES STBY EMLE Address bus Data bus A23 to A0 D15 to D0
Bus control
BREQ BREQO
Rev.2.00 Jun. 28, 2007 Page 10 of 666 REJ09B0311-0200
Section 1 Overview
Classification Bus control
Pin Name BACK BS-A/BS-B AS
I/O Output Output Output
Description Bus acknowledge signal, which indicates that the bus has been released. Indicates the start of a bus cycle. Strobe signal which indicates that the output address on the address bus is valid in access to the basic bus interface or byte control SRAM interface space. This signal is used to hold the address when accessing the address-data multiplexed I/O interface space. Strobe signal which indicates that reading from the basic bus interface space is in progress. Indicates the direction (input or output) of the data bus. Strobe signal which indicates that the higher-order byte (D15 to D8) is valid in access to the basic bus interface space. Strobe signal which indicates that the lower-order byte (D7 to D0) is valid in access to the basic bus interface space. Strobe signal which indicates that the higher-order byte (D15 to D8) is valid in access to the byte control SRAM interface space. Strobe signal which indicates that the lower-order byte (D7 to D0) is valid in access to the byte control SRAM interface space. Select signals for areas 0 to 7.
AH RD RD/WR LHWR
Output Output Output Output
LLWR LUB
Output Output
LLB
Output
CS0 CS1 CS2-A/CS2-B CS3 CS4-A/CS4-C CS5-A/CS5-B/ CS5-C/CS5-D CS6-A/CS6-B/ CS6-C/CS6-D CS7-A/CS7-B/ CS7-C WAIT
Output
Input
Requests wait cycles in access to the external space.
Rev.2.00 Jun. 28, 2007 Page 11 of 666 REJ09B0311-0200
Section 1 Overview
Classification Interrupt
Pin Name NMI IRQ11-A/IRQ11-B IRQ10-A/IRQ10-B IRQ9-A/IRQ9-B IRQ8-A/IRQ8-B IRQ7-A/IRQ7-B IRQ6-A/IRQ6-B IRQ5-A/IRQ5-B IRQ4-A/IRQ4-B IRQ3-A/IRQ3-B IRQ2-A/IRQ2-B IRQ1-A/IRQ1-B IRQ0-A/IRQ0-B
I/O Input Input
Description Non-maskable interrupt request signal. When this pin is not in use, this signal must be fixed high. Maskable interrupt request signal.
16-bit timer TCLKA-A/TCLKA-B Input pulse unit (TPU) TCLKB-A/TCLKB-B TCLKC-A/TCLKC-B TCLKD-A/TCLKD-B TIOCA0 TIOCB0 TIOCC0 TIOCD0 TIOCA1 TIOCB1 Input/ output
Input pins for the external clock signals.
Signals for TGRA_0 to TGRD_0. These pins are used as input capture inputs, output compare outputs, or PWM outputs. Signals for TGRA_1 and TGRB_1. These pins are used as input capture inputs, output compare outputs, or PWM outputs.
Input/ output
Rev.2.00 Jun. 28, 2007 Page 12 of 666 REJ09B0311-0200
Section 1 Overview
Classification
Pin Name
I/O Input/ output Input/ output
Description Signals for TGRA_2 and TGRB_2. These pins are used as input capture inputs, output compare outputs, or PWM outputs. Signals for TGRA_3 to TGRD_3. These pins are used as input capture inputs, output compare outputs, or PWM outputs. Signals for TGRA_4 and TGRB_4. These pins are used as input capture inputs, output compare outputs, or PWM outputs. Signals for TGRA_5 and TGRB_5. These pins are used as input capture inputs, output compare outputs, or PWM outputs. Output pins for the pulse signals.
16-bit timer TIOCA2 pulse unit (TPU) TIOCB2 TIOCA3 TIOCB3 TIOCC3 TIOCD3 TIOCA4 TIOCB4 TIOCA5 TIOCB5 Programmable pulse generator (PPG) 8-bit timer (TMR) PO15 to PO0
Input/ output Input/ output Output
TMO0 to TMO3 TMCI0 to TMCI3 TMRI0 to TMRI3
Output Input Input Output Output
Output pins for the compare match signals. Input pins for the external clock signals that drive for the counters. Input pins for the counter-reset signals. Output pin for the counter-overflow signal in watchdog-timer mode. Output pins for data transmission.
Watchdog timer WDTOVF (WDT) Serial communication interface (SCI) TxD0 to TxD4
RxD0 to RxD4 SCK0 to SCK4
Input Input/ output
Input pins for data reception. Input/output pins for clock signals.
Rev.2.00 Jun. 28, 2007 Page 13 of 666 REJ09B0311-0200
Section 1 Overview
Classification A/D converter
Pin Name AN7 to AN0 ADTRG0
I/O Input Input Output
Description Input pins for the analog signals to be processed by the A/D converter. Input pin for the external trigger signal that starts A/D conversion. Output pins for the analog signals from the D/A converter. Analog power supply pin for the A/D and D/A converters. When the A/D and D/A converters are not in use, connect this pin to the system power supply. Ground pin for the A/D and D/A converters. Connect this pin to the system power supply (0 V). Reference power supply pin for the A/D and D/A converters. When the A/D and D/A converters are not in use, connect this pin to the system power supply. 8 input/output pins. 8 input/output pins. 8 input/output pins. 8 input/output pins. 6 input/output pins. 5 input/output pins. 4 input/output pins. 3 input/output pins. 8 input/output pins.
D/A converter A/D converter, D/A converter
DA1 DA0 AVCC
AVSS Vref

I/O ports
P17 to P10 P27 to P20 P37 to P30 P57 to P50 P65 to P60 PA6, PA4 PA2 to PA0 PB3 to PB0 PF7 to PF5 PI7 to PI0
Input/ output Input/ output Input/ output Input Input/ output Input/ output Input/ output Input/ output Input/ output
Rev.2.00 Jun. 28, 2007 Page 14 of 666 REJ09B0311-0200
Section 2 CPU
Section 2 CPU
The H8SX CPU is a high-speed central processing unit with an internal 32-bit architecture that is upward-compatible with the H8/300, H8/300H, and H8S CPUs. The H8SX CPU has sixteen 16bit general registers, can handle a 4-Gbyte linear address space, and is ideal for a realtime control system.
2.1
Features
* High-speed CPU that is upward-compatible with H8/300, H8/300H, and H8S CPUs Can execute these CPU's object programs * General-register architecture Sixteen 16-bit general registers (also usable as sixteen 8-bit registers or eight 32-bit registers) * 87 basic instructions 8/16/32-bit arithmetic and logic instructions Multiply and divide instructions Bit field transfer instructions Powerful bit-manipulation instructions Bit condition branch instructions Multiply-and-accumulate instruction * Eleven addressing modes Register direct [Rn] Register indirect [@ERn] Register indirect with displacement [@(d:2,ERn), @(d:16,ERn), or @(d:32,ERn)] Index register indirect with displacement [@(d:16,RnL.B), @(d:32,RnL.B), @(d:16,Rn.W), @(d:32,Rn.W), @(d:16,ERn.L), or @(d:32,ERn.L)] Register indirect with post-/pre-increment or post-/pre-decrement [@+ERn/@-ERn/@ERn+/@ERn-] Absolute address [@aa:8, @aa:16, @aa:24, or @aa:32] Immediate [#xx:3, #xx:4, #xx:8, #xx:16, or #xx:32] Program-counter relative [@(d:8,PC) or @(d:16,PC)] Program-counter relative with index register [@(RnL.B,PC), @(Rn.W,PC), or @(ERn.L,PC)] Memory indirect [@@aa:8] Extended memory indirect [@@vec:7]
Rev.2.00 Jun. 28, 2007 Page 15 of 666 REJ09B0311-0200
Section 2 CPU
* Two base registers Vector base register Short address base register * 4-Gbyte address space Program: 4 Gbytes Data: 4 Gbytes * High-speed operation All frequently-used instructions execute in one or two states 8/16/32-bit register-register add/subtract: 1 state 8 x 8-bit register-register multiply: 1 state 16 / 8-bit register-register divide: 10 states 16 x 16-bit register-register multiply: 1 state 32 / 16-bit register-register divide: 18 states 32 x 32-bit register-register multiply: 5 states 32 / 32-bit register-register divide: 18 states * Four CPU operating modes Normal mode Middle mode Advanced mode Maximum mode * Power-down modes Transition is made by execution of SLEEP instruction Choice of CPU operating clocks Notes: 1. Advanced mode is only supported as the CPU operating mode of the H8SX/1650 Group. Normal, middle, and maximum modes are not supported. 2. The multiplier and divider are supported by the H8SX/1650 Group.
Rev.2.00 Jun. 28, 2007 Page 16 of 666 REJ09B0311-0200
Section 2 CPU
2.2
CPU Operating Modes
The H8SX CPU has four operating modes: normal, middle, advanced, and maximum modes. As for selecting the mode, see section 3.1, Operating Mode Selection.
Maximum 64 Kbytes for program Normal mode and data areas combined Maximum 16-Mbyte program Middle mode area and 64-Kbyte data area, maximum 16 Mbytes for program and data areas combined CPU operating modes Maximum 16-Mbyte program Advanced mode area and 4-Gbyte data area, maximum 4 Gbytes for program and data areas combined Maximum 4 Gbytes for program and data areas combined
Maximum mode
Figure 2.1 CPU Operating Modes 2.2.1 Normal Mode
In normal mode, the exception handling vector table and stack have the same structure as in the H8/300 CPU. Note This LSI does not support this mode.
* Address Space A maximum address space of 64 kbytes can be accessed. * Extended Registers (En) The extended registers (E0 to E7) can be used as 16-bit registers, or as the upper 16-bit segments of 32-bit registers. When En is used as a 16-bit register it can contain any value, even when the corresponding general register (Rn) is used as an address register. If the general register Rn is referenced in the register indirect addressing mode with pre-/post-increment or decrement and a carry or borrow occurs, however, the value in the corresponding extended register will be affected. * Instruction Set All instructions and addressing modes can be used. Only the lower 16 bits of effective addresses (EA) are valid.
Rev.2.00 Jun. 28, 2007 Page 17 of 666 REJ09B0311-0200
Section 2 CPU
* Exception Handling Vector Table and Memory Indirect Branch Addresses In normal mode, the top area starting at H'0000 is allocated to the exception handling vector table. One branch address is stored per 16 bits. The structure of the exception handling vector table is shown in figure 2.2.
H'0000 H'0001 H'0002 H'0003
Reset exception vector Reset exception vector Exception vector table
Figure 2.2 Exception Handling Vector Table (Normal Mode) The memory indirect (@@aa:8) and extended memory indirect (@@vec:7) addressing modes are used in the JMP and JSR instructions. An 8-bit absolute address included in the instruction code specifies a memory location. Execution branches to the address contained in the memory location. * Stack Structure The stack structure of PC at a subroutine branch and that of PC and CCR at an exception handling branch are shown in figure 2.3. The PC contents are saved or restored in 16-bit units.
SP
PC (16 bits)
SP *2 (SP )
EXR*1 Reserved*1,*3 CCR CCR*3 PC (16 bits)
(a) Subroutine Branch
(b) Exception Handling
Notes: 1. When EXR is not used it is not stored on the stack. 2. SP when EXR is not used. 3. Ignored on return.
Figure 2.3 Stack Structure in Normal Mode
Rev.2.00 Jun. 28, 2007 Page 18 of 666 REJ09B0311-0200
Section 2 CPU
2.2.2
Middle Mode
The program area in middle mode is extended to 16 Mbytes as compared with that in normal mode. * Address Space A maximum address space of 16 Mbytes can be accessed in a total of the program and data areas. For individual areas, up to 16 Mbytes of the program area and up to 64 Kbytes of the data area can be allocated. * Extended Registers (En) The extended registers (E0 to E7) can be used as 16-bit registers, or as the upper 16-bit segments of 32-bit registers. When En is used as a 16-bit register (in other than the JMP and JSR instructions), it can contain any value even when the corresponding general register (Rn) is used as an address register. If the general register Rn is referenced in the register indirect addressing mode with pre-/post-increment or decrement and a carry or borrow occurs, however, the value in the corresponding extended register will be affected. * Instruction Set All instructions and addressing modes can be used. Only the lower 16 bits of effective addresses (EA) are valid and the upper eight bits are sign-extended. * Exception Handling Vector Table and Memory Indirect Branch Addresses In middle mode, the top area starting at H'000000 is allocated to the exception handling vector table in 32-bit units. In each 32 bits, the upper eight bits are ignored and one branch address is stored in the lower 24 bits. The structure of the exception handling vector table is shown in figure 2.4. The memory indirect (@@aa:8) and extended memory indirect (@@vec:7) addressing modes are used in the JMP and JSR instructions. An 8-bit absolute address included in the instruction code specifies a memory location. Execution branches to the contents of the memory location. In middle mode, an operand is a 32-bit (longword) operand, providing a 32-bit branch address. The upper eight bits are reserved and assumed to be H'00. * Stack Structure The stack structure of PC at a subroutine branch and that of PC and CCR at an exception handling branch are shown in figure 2.5. The PC contents are saved or restored in 24-bit units.
Rev.2.00 Jun. 28, 2007 Page 19 of 666 REJ09B0311-0200
Section 2 CPU
2.2.3
Advanced Mode
The data area in advanced mode is extended to 4 Gbytes as compared with that in middle mode. * Address Space A maximum address space of 4 Gbytes can be linearly accessed. For individual areas, up to 16 Mbytes of the program area and up to 4 Gbytes of the data area can be allocated. * Extended Registers (En) The extended registers (E0 to E7) can be used as 16-bit registers, or as the upper 16-bit segments of 32-bit registers or address registers. * Instruction Set All instructions and addressing modes can be used. * Exception Handling Vector Table and Memory Indirect Branch Addresses In advanced mode, the top area starting at H'00000000 is allocated to the exception handling vector table in 32-bit units. In each 32 bits, the upper eight bits are ignored and one branch address is stored in the lower 24 bits. The structure of the exception handling vector table is shown in figure 2.4.
H'00000000 H'00000001 H'00000002 H'00000003 H'00000004 H'00000005 H'00000006 H'00000007 Reserved Exception vector table Reset exception vector Reserved
Figure 2.4 Exception Handling Vector Table (Middle and Advanced Modes) The memory indirect (@@aa:8) and extended memory indirect (@@vec:7) addressing modes are used in the JMP and JSR instructions. An 8-bit absolute address included in the instruction code specifies a memory location. Execution branches to the contents of the memory location. In advanced mode, an operand is a 32-bit (longword) operand, providing a 32-bit branch address. The upper eight bits are eserved and assumed to be H'00.
Rev.2.00 Jun. 28, 2007 Page 20 of 666 REJ09B0311-0200
Section 2 CPU
* Stack Structure The stack structure of PC at a subroutine branch and that of PC and CCR at an exception handling branch are shown in figure 2.5. The PC contents are saved or restored in 24-bit units.
SP SP Reserved PC (24 bits) (SP *2 )
EXR*1 Reserved*1,*3 CCR PC (24 bits)
(a) Subroutine Branch
(b) Exception Handling
Notes: 1. When EXR is not used it is not stored on the stack. 2. SP when EXR is not used. 3. Ignored on return.
Figure 2.5 Stack Structure in Middle and Advanced Modes 2.2.4 Maximum Mode
The program area in maximum mode is extended to 4 Gbytes as compared with that in advanced mode. * Address Space A maximum address space of 4 Gbytes can be linearly accessed. * Extended Registers (En) The extended registers (E0 to E7) can be used as 16-bit registers or as the upper 16-bit segments of 32-bit registers or address registers. * Instruction Set All instructions and addressing modes can be used. * Exception Handling Vector Table and Memory Indirect Branch Addresses In maximum mode, the top area starting at H'00000000 is allocated to the exception handling vector table in 32-bit units. One branch address is stored in 32 bits. The structure of the exception handling vector table is shown in figure 2.6.
Rev.2.00 Jun. 28, 2007 Page 21 of 666 REJ09B0311-0200
Section 2 CPU
H'00000000 H'00000001 H'00000002 H'00000003 H'00000004 H'00000005 H'00000006 H'00000007 Exception vector table Reset exception vector
Figure 2.6 Exception Handling Vector Table (Maximum Modes) The memory indirect (@@aa:8) and extended memory indirect (@@vec:7) addressing modes are used in the JMP and JSR instructions. An 8-bit absolute address included in the instruction code specifies a memory location. Execution branches to the contents of the memory location. In maximum mode, an operand is a 32-bit (longword) operand, providing a 32-bit branch address. * Stack Structure The stack structure of PC at a subroutine branch and that of PC and CCR at an exception handling branch are shown in figure 2.7. The PC contents are saved or restored in 32-bit units. The EXR contents are saved or restored regardless of whether or not EXR is in use.
SP PC (32 bits)
SP
EXR CCR PC (32 bits)
(a) Subroutine Branch
(b) Exception Handling
Figure 2.7 Stack Structure in Maximum Mode
Rev.2.00 Jun. 28, 2007 Page 22 of 666 REJ09B0311-0200
Section 2 CPU
2.3
Instruction Fetch
The H8SX CPU has two modes for instruction fetch: 16-bit and 32-bit modes. It is recommended that the mode should be set according to the bus width of the memory in which the program is stored. The instruction-fetch mode setting does not affect operation other than instruction fetch such as data accesses. The FETCHMD bit in SYSCR selects one of the two modes. For details, see section 3.2.2, System Control Register (SYSCR).
2.4
Address Space
Figure 2.8 shows a memory map of the H8SX CPU. The address space differs depending on the operating mode.
Normal mode H'0000 H'000000 H'007FFF Program area Data area (64 Kbytes) Middle mode H'00000000 Advanced mode H'00000000 Maximum mode
H'FFFF
Program area (16 Mbytes) Program area (16 Mbytes)
Data area (64 Kbytes)
H'FF8000 H'FFFFFF H'00FFFFFF
Program area Data area (4 Gbytes)
Data area (4 Gbytes)
H'FFFFFFFF
H'FFFFFFFF
Figure 2.8 Memory Map
Rev.2.00 Jun. 28, 2007 Page 23 of 666 REJ09B0311-0200
Section 2 CPU
2.5
Registers
The H8SX CPU has the internal registers shown in figure 2.9. There are two types of registers: general registers and control registers. The control registers are the 32-bit program counter (PC), 8-bit extended control register (EXR), 8-bit condition-code register (CCR), 32-bit vector base register (VBR), 32-bit short address base register (SBR), and 64-bit multiply-accumulate register (MAC).
General Registers and Extended Registers 15 ER0 ER1 ER2 ER3 ER4 ER5 ER6 ER7 (SP) Control Registers 31 PC E0 E1 E2 E3 E4 E5 E6 E7 07 R0H R1H R2H R3H R4H R5H R6H R7H 07 R0L R1L R2L R3L R4L R5L R6L R7L 0
0
76543210
CCR
I UI H U N Z V C
76543210 EXR
T -- -- -- -- I2 I1 I0
31 VBR 31 SBR 63 MAC Sign extension MACL
12 (Reserved) 8 (Reserved) 41 MACH
0 0 32
31 [Legend] SP: Stack pointer PC: Program counter CCR: Condition-code register Interrupt mask bit I: User bit or interrupt mask bit UI: Half-carry flag H: User bit U: Negative flag N:
0 Z: V: C: EXR: T: I2 to I0: VBR: SBR: MAC: Zero flag Overflow flag Carry flag Extended control register Trace bit Interrupt mask bits Vector base register Short address base register Multiply-accumulate register
Figure 2.9 CPU Registers
Rev.2.00 Jun. 28, 2007 Page 24 of 666 REJ09B0311-0200
Section 2 CPU
2.5.1
General Registers
The H8SX CPU has eight 32-bit general registers. These general registers are all functionally alike and can be used as both address registers and data registers. When a general register is used as a data register, it can be accessed as a 32-bit, 16-bit, or 8-bit register. Figure 2.10 illustrates the usage of the general registers. When the general registers are used as 32-bit registers or address registers, they are designated by the letters ER (ER0 to ER7). The ER registers are divided into 16-bit general registers designated by the letters E (E0 to E7) and R (R0 to R7). These registers are functionally equivalent, providing a maximum of sixteen 16bit registers. The E registers (E0 to E7) are also referred to as extended registers. The R registers are divided into 8-bit general registers designated by the letters RH (R0H to R7H) and RL (R0L to R7L). These registers are functionally equivalent, providing a maximum of sixteen 8-bit registers. The general registers ER (ER0 to ER7), R (R0 to R7), and RL (R0L to R7L) are also used as index registers. The size in the operand field determines which register is selected. The usage of each register can be selected independently.
* Address registers * 32-bit registers * 32-bit index registers General registers ER (ER0 to ER7) * 16-bit registers General registers E (E0 to E7) * 16-bit registers * 16-bit index registers General registers R (R0 to R7) * 8-bit registers General registers RH (R0H to R7H) * 8-bit registers * 8-bit index registers General registers RL (R0L to R7L)
Figure 2.10 Usage of General Registers General register ER7 has the function of stack pointer (SP) in addition to its general-register function, and is used implicitly in exception handling and subroutine calls. Figure 2.11 shows the stack.
Rev.2.00 Jun. 28, 2007 Page 25 of 666 REJ09B0311-0200
Section 2 CPU
Free area
SP (ER7)
Stack area
Figure 2.11 Stack 2.5.2 Program Counter (PC)
PC is a 32-bit counter that indicates the address of the next instruction the CPU will execute. The length of all CPU instructions is two bytes (one word) or a multiple of two bytes, so the least significant PC bit is ignored. When an instruction is fetched, the least significant PC bit is regarded as 0. 2.5.3 Condition-Code Register (CCR)
CCR is an 8-bit register that contains internal CPU status information, including an interrupt mask (I) and user (UI, U) bits and half-carry (H), negative (N), zero (Z), overflow (V), and carry (C) flags. Operations can be performed on the CCR bits by the LDC, STC, ANDC, ORC, and XORC instructions. The N, Z, V, and C flags are used as branching conditions for conditional branch (Bcc) instructions.
Bit 7 Bit Name I Initial Value 1 R/W R/W Description Interrupt Mask Bit Masks interrupts when set to 1. This bit is set to 1 at the start of an exception-handling sequence. 6 UI Undefined R/W User Bit or Interrupt Mask Bit Can be written and read by software using the LDC, STC, ANDC, ORC, and XORC instructions. This bit can also be used as an interrupt mask bit.
Rev.2.00 Jun. 28, 2007 Page 26 of 666 REJ09B0311-0200
Section 2 CPU
Bit 5
Bit Name H
Initial Value
R/W
Description Half-Carry Flag When the ADD.B, ADDX.B, SUB.B, SUBX.B, CMP.B, or NEG.B instruction is executed, this flag is set to 1 if there is a carry or borrow at bit 3, and cleared to 0 otherwise. When the ADD.W, SUB.W, CMP.W, or NEG.W instruction is executed, the H flag is set to 1 if there is a carry or borrow at bit 11, and cleared to 0 otherwise. When the ADD.L, SUB.L, CMP.L, or NEG.L instruction is executed, the H flag is set to 1 if there is a carry or borrow at bit 27, and cleared to 0 otherwise.
Undefined R/W
4
U
Undefined R/W
User Bit Can be written and read by software using the LDC, STC, ANDC, ORC, and XORC instructions.
3
N
Undefined R/W
Negative Flag Stores the value of the most significant bit (regarded as sign bit) of data.
2
Z
Undefined R/W
Zero Flag Set to 1 to indicate zero data, and cleared to 0 to indicate non-zero data.
1
V
Undefined R/W
Overflow Flag Set to 1 when an arithmetic overflow occurs, and cleared to 0 otherwise.
0
C
Undefined R/W
Carry Flag Set to 1 when a carry occurs, and cleared to 0 otherwise. A carry flag indicates the following: * * * A carry by an add instruction A borrow by a subtract instruction A carry by a shift or rotate instruction
The carry flag is also used as a bit accumulator by bit manipulation instructions.
Rev.2.00 Jun. 28, 2007 Page 27 of 666 REJ09B0311-0200
Section 2 CPU
2.5.4
Extended Control Register (EXR)
EXR is an 8-bit register that contains the trace bit (T) and three interrupt mask bits (I2 to I0). Operations can be performed on the EXR bits by the LDC, STC, ANDC, ORC, and XORC instructions. For details, see section 4, Exception Handling.
Bit 7 Bit Name T Initial Value 0 R/W R/W Description Trace Bit Selects trace mode. When this bit is cleared to 0, instructions are executed in sequence. When this bit is set to 1, a trace exception is generated each time an instruction is executed. 6 to 3 All 1 R/W Reserved These bits are always read as 1. The write value should always be 1. 2 1 0 I2 I1 I0 1 1 1 R/W R/W R/W Interrupt Mask Bits These bits designate the interrupt mask level (0 to 7).
2.5.5
Vector Base Register (VBR)
VBR is a 32-bit register that has the valid upper 20 bits. The lower 12 bits of this register are read as 0s. This register value is a base address of the vector area for exception handling other than a reset and a CPU address error (extended memory indirect is also out of the target). The initial value is H'00000000. 2.5.6 Short Address Base Register (SBR)
SBR is a 32-bit register that has the valid upper 24 bits. The lower eight bits are read as 0s. In 8-bit absolute addressing mode (@aa:8), this register is used as the upper address. The initial value is H'FFFFFF00.
Rev.2.00 Jun. 28, 2007 Page 28 of 666 REJ09B0311-0200
Section 2 CPU
2.5.7
Multiply-Accumulate Register (MAC)
MAC is a 64-bit register that stores the results of multiply-and-accumulate operations. It consists of two 32-bit registers denoted MACH and MACL. The lower 10 bits of MACH are valid; the upper bits are sign-extended. 2.5.8 Initial Register Values
Reset exception handling loads the start address from the vector table into the PC contents, clears the trace bit in EXR to 0, and sets the interrupt mask bits in CCR and EXR to 1. The other CCR bits, MAC and the general registers are not initialized. In particular, the stack pointer (ER7) is not initialized. The stack pointer should therefore be initialized using an MOV.L instruction executed immediately after a reset.
Rev.2.00 Jun. 28, 2007 Page 29 of 666 REJ09B0311-0200
Section 2 CPU
2.6
Data Formats
The H8SX CPU can process 1-bit, 4-bit BCD, 8-bit (byte), 16-bit (word), and 32-bit (longword) data. Bit-manipulation instructions operate on 1-bit data by accessing bit n (n = 0, 1, 2, ..., 7) of byte operand data. The DAA and DAS decimal-adjust instructions treat byte data as two digits of 4-bit BCD data. 2.6.1 General Register Data Formats
Figure 2.12 shows the data formats in general registers.
0 7 76543210
1-bit data
RnH
Don't care 7 0 76543210
1-bit data
RnL
Don't care 7 Upper 43 0 Lower
4-bit BCD data
RnH
Don't care 7 43 0 Lower
4-bit BCD data
RnL Don't care
Upper 0
Byte data
RnH 7 Don't care MSB LSB 7 Don't care MSB 15 0 LSB 0 LSB
Byte data
RnL
Word data
Rn
Word data
En
Longword data
ERn
MSB 0 LSB 16 15 En Rn RnL: General register RL MSB: Most significant bit LSB: Least significant bit
15 MSB 31 MSB
0 LSB
[Legend] ERn: General register ER En: General register E Rn: General register R RnH: General register RH
Figure 2.12 General Register Data Formats
Rev.2.00 Jun. 28, 2007 Page 30 of 666 REJ09B0311-0200
Section 2 CPU
2.6.2
Memory Data Formats
Figure 2.13 shows the data formats in memory. The H8SX CPU can access word data and longword data that are stored at any addresses in memory. When word data begin at an odd address or longword data begin at an address other than a multiple of 4, a bus cycle is divided into two or more accesses. For example, when longword data begins at an odd address, the bus cycle is divided into byte, word, and byte accesses. In this case, these accesses are assumed to be individual bus cycles. However, instructions to be fetched, word and longword data to be accessed during execution of the stack manipulation, block transfer instructions, and MAC instruction should be located to even addresses. When the stack pointer (ER7) is used as an address register to access the stack, the operand size should be word size or longword size.
Data Type Address 7 1-bit data Address L 7 6 5 4 3 2 1 0 0 Data Format
Byte data
Address L MSB
LSB
Word data
Address 2M MSB Address 2M + 1 LSB
Longword data
Address 2N MSB Address 2N + 1 Address 2N + 2 Address 2N + 3 LSB
Figure 2.13 Memory Data Formats
Rev.2.00 Jun. 28, 2007 Page 31 of 666 REJ09B0311-0200
Section 2 CPU
2.7
Instruction Set
The H8SX CPU has 87 types of instructions. The instructions are classified by function as shown in table 2.1. Table 2.1
Function Data transfer
Instruction Classification
Instructions MOV MOVFPE* , MOVTPE* POP, PUSH* LDM, STM MOVA
1 6 6
Size B/W/L B W/L L B/W*2 B B/W/L B B/W/L B L B/W W/L L W/L B B/W/L
Types 6
Block transfer
EEPMOV MOVMD MOVSD
3
Arithmetic operations
ADD, ADDX, SUB, SUBX, CMP, NEG, INC, DEC DAA, DAS ADDS, SUBS MULXU, DIVXU, MULXS, DIVXS MULU, DIVU, MULS, DIVS MULU/U, MULS/U EXTU, EXTS TAS MAC LDMAC, STMAC CLRMAC
27
Logic operations Shift Bit manipulation
AND, OR, XOR, NOT
4 8 20
SHLL, SHLR, SHAL, SHAR, ROTL, ROTR, ROTXL, ROTXR B/W/L BSET, BCLR, BNOT, BTST, BAND, BIAND, BOR, BIOR, BXOR, BIXOR, BLD, BILD, BST, BIST BSET/EQ, BSET/NE, BCLR/EQ, BCLR/NE, BSTZ, BISTZ BFLD, BFST B B B
Rev.2.00 Jun. 28, 2007 Page 32 of 666 REJ09B0311-0200
Section 2 CPU
Function Branch
Instructions BRA/BS, BRA/BC, BSR/BS, BSR/BC Bcc* , JMP, BSR, JSR, RTS RTS/L BRA/S
4
Size B* L*5 L*
5 3
Types 9
System control
TRAPA, RTE, SLEEP, NOP RTE/L LDC, STC, ANDC, ORC, XORC
10
B/W/L Total 87
[Legend] B: Byte size W: Word size L: Longword size Notes: 1. POP.W Rn and PUSH.W Rn are identical to MOV.W @SP+, Rn and MOV.W Rn, @-SP. POP.L ERn and PUSH.L ERn are identical to MOV.L @SP+, ERn and MOV.L ERn, @-SP. 2. Size of data to be added with a displacement 3. Size of data to specify a branch condition 4. Bcc is the generic designation of a conditional branch instruction. 5. Size of a general register to be restored 6. Not supported in this LSI
Rev.2.00 Jun. 28, 2007 Page 33 of 666 REJ09B0311-0200
Section 2 CPU
2.7.1
Instructions and Addressing Modes
Table 2.2 indicates the combinations of instructions and addressing modes that the H8SX CPU can use. Table 2.2 Combinations of Instructions and Addressing Modes (1)
Addressing Mode @(d, Classification Data transfer MOVFPE, MOVTPE*
12
@-ERn/ @ERn-/ @aa:8 @aa:16/ @aa:32 SD S/D S/D*1
RnL.B/ @ERn+/ Rn.W/ Instruction MOV Size B/W/L B B #xx S Rn SD S/D S/D @ERn SD @(d,ERn) ERn.L) @+ERn SD SD SD
POP, PUSH LDM, STM MOVA*4 Block transfer EEPMOV MOVMD MOVSD Arithmetic operations ADD, CMP SUB
W/L L B/W B B/W/L B B/W/L B B W/L S S S S S S
S/D S/D S S S S
S/D*2 S/D*2 S S SD*3 SD*3 SD*3
SD
SD D
SD D SD SD
SD D SD SD
SD D SD SD
SD D SD SD
SD SD SD
SD SD
ADDX, SUBX
B/W/L B/W/L B/W/L
SD SD*5 D D D
INC, DEC ADDS, SUBS DAA, DAS MULXU, DIVXU MULU, DIVU MULXS, DIVXS
B/W/L L B B/W W/L B/W S:4 S:4 S:4
SD SD SD
Rev.2.00 Jun. 28, 2007 Page 34 of 666 REJ09B0311-0200
Section 2 CPU
Addressing Mode @(d, Classification Arithmetic operations Instruction MULS, DIVS NEG EXTU, EXTS TAS MAC CLRMAC LDMAC STMAC Logic operations Shift AND, OR, XOR NOT SHLL, SHLR Size W/L B/W/L W/L B B/W/L B/W/L B/W/L* B/W/L* SHAL, SHAR ROTL, ROTR B/W/L B/W/L
6
@-ERn/ @ERn-/ @aa:8 @aa:16/ @aa:32
RnL.B/ @ERn+/ Rn.W/ #xx S:4 Rn SD D D D D D D D D D D D D D @ERn @(d,ERn) ERn.L) @+ERn
O S D S SD D D D D D D D D D D D D D D D D D D D D D D D D D SD D D SD D D SD D D SD D D SD D D
7
ROTXL, ROTXR B/W/L Bit manipulation BSET, BCLR, BNOT, BTST, BSET/cc, BCLR/cc BAND, BIAND, BOR, BIOR, BXOR, BIXOR, BLD, BILD, BST, BIST, BSTZ, BISTZ BFLD BFST Branch BRA/BS, BRA/BC*8 BSR/BS, BSR/BC*8 B B B B B B
D
D
D
D
D S
S D S
S D S
S D S
S
S
S
Rev.2.00 Jun. 28, 2007 Page 35 of 666 REJ09B0311-0200
Section 2 CPU
Addressing Mode @(d, Classification System control Instruction LDC (CCR, EXR) LDC (VBR, SBR) STC (CCR, EXR) STC (VBR, SBR) ANDC, ORC, XORC SLEEP NOP O O B S L D B/W*9 D D D D*11 D L S Size B/W*
9
@-ERn/ @ERn-/ @aa:8 @aa:16/ @aa:32 S
RnL.B/ @ERn+/ Rn.W/ #xx S Rn S @ERn S @(d,ERn) ERn.L) @+ERn S S*
10
[Legend] d: d:16 or d:32 S: Can be specified as a source operand. D: Can be specified as a destination operand. SD: Can be specified as either source or destination operand or both. S/D: Can be specified as either source or destination operand. S:4: 4-bit immediate data can be specified as a source operand. Notes: 1. @aa:16 is only available. 2. @ERn+ as a source operand and @-ERn as a destination operand 3. Specified by ER5 as a source address and ER6 as a destination address for data transfer 4. Size of data to be added with a displacement 5. @ERn- is only available. 6. When the number of bits to be shifted is 1, 2, 4, 8, or 16 7. When the number of bits to be shifted is specified by 5-bit immediate data or a general register 8. Size of data to specify a branch condition 9. Byte for immediate or register direct; otherwise, word 10. @ERn+ is only available. 11. @-ERn is only available. 12. Not supported in this LSI
Rev.2.00 Jun. 28, 2007 Page 36 of 666 REJ09B0311-0200
Section 2 CPU
Table 2.2
Combinations of Instructions and Addressing Modes (2)
Addressing Mode @(RnL.B/ Rn.W/
Classification Branch Instruction BRA/BS, BRA/BC BSR/BS, BSR/BC Bcc BRA BRA/S JMP BSR JSR RTS, RTS/L System control TRAPA RTE, RTE/L O O O O O O* O Size @ERn @(d,PC) O
ERn.L, PC) @aa:24 @aa:32 @@aa:8 @@vec:7
O
O
O
O
O
O
O
O
O O O O
[Legend] d: d:8 or d:16 Note: * @(d:8, PC) is only available.
Rev.2.00 Jun. 28, 2007 Page 37 of 666 REJ09B0311-0200
Section 2 CPU
2.7.2
Table of Instructions Classified by Function
Tables 2.4 to 2.11 summarize the instructions in each functional category. The notation used in the tables is defined in table 2.3. Table 2.3 Operation Notation
Description General register (destination)* General register (source)* General register* General register (32-bit register) Destination operand Source operand Extended control register Condition-code register Vector base register Short address base register N (negative) flag in CCR Z (zero) flag in CCR V (overflow) flag in CCR C (carry) flag in CCR Program counter Stack pointer Immediate data Displacement Addition Subtraction Multiplication Division Logical AND Logical OR Logical exclusive OR Move Logical not (logical complement) 8-, 16-, 24-, or 32-bit length
Operation Notation Rd Rs Rn ERn (EAd) (EAs) EXR CCR VBR SBR N Z V C PC SP #IMM disp + - x / :8/:16/:24/:32 Note: *
General registers include 8-bit registers (R0H to R7H, R0L to R7L), 16-bit registers (R0 to R7, E0 to E7), and 32-bit registers (ER0 to ER7).
Rev.2.00 Jun. 28, 2007 Page 38 of 666 REJ09B0311-0200
Section 2 CPU
Table 2.4
Instruction MOV MOVFPE* MOVTPE* POP PUSH LDM
Data Transfer Instructions
Size B/W/L B B W/L W/L L Function #IMM (EAd), (EAs) (EAd) Transfers data between immediate data, general registers, and memory. (EAs) Rd Rs (EAs) @SP+ Rn Restores the data from the stack to a general register. Rn @-SP Saves general register contents on the stack. @SP+ Rn (register list) Restores the data from the stack to general registers. Two, three, or four general registers which have serial register numbers can be specified.
STM
L
Rn (register list) @-SP Saves the contents of general registers on the stack. Two, three, or four general registers which have serial register numbers can be specified.
MOVA
B/W
EA Rd Zero-extends the contents of a specified general register or memory data and adds them with a displacement. The result is stored in a general register.
Note
*
Not supported in this LSI
Rev.2.00 Jun. 28, 2007 Page 39 of 666 REJ09B0311-0200
Section 2 CPU
Table 2.5
Instruction EEPMOV.B EEPMOV.W
Block Transfer Instructions
Size B Function Transfers a data block. Transfers byte data from a memory location specified by ER5 to a memory location specified by ER6. The number of byte data to be transferred is specified by R4 or R4L. B Transfers a data block. Transfers byte data from a memory location specified by ER5 to a memory location specified by ER6. The number of byte data to be transferred is specified by R4.
MOVMD.B
MOVMD.W
W
Transfers a data block. Transfers word data from a memory location specified by ER5 to a memory location specified by ER6. The number of word data to be transferred is specified by R4.
MOVMD.L
L
Transfers a data block. Transfers longword data from a memory location specified by ER5 to a memory location specified by ER6. The number of longword data to be transferred is specified by R4.
MOVSD.B
B
Transfers a data block with zero data detection. Transfers byte data from a memory location specified by ER5 to a memory location specified by ER6. The number of byte data to be transferred is specified by R4. When zero data is detected during transfer, the transfer stops and execution branches to a specified address.
Rev.2.00 Jun. 28, 2007 Page 40 of 666 REJ09B0311-0200
Section 2 CPU
Table 2.6
Instruction ADD SUB
Arithmetic Operation Instructions
Size B/W/L Function (EAd) #IMM (EAd), (EAd) (EAs) (EAd) Performs addition or subtraction on data between immediate data, general registers, and memory. Immediate byte data cannot be subtracted from byte data in a general register. B/W/L (EAd) #IMM C (EAd), (EAd) (EAs) C (EAd) Performs addition or subtraction with carry on data between immediate data, general registers, and memory. A memory location can be specified in the register indirect addressing mode with post-decrement or the register indirect addressing mode. B/W/L Rd 1 Rd, Rd 2 Rd Increments or decrements a general register by 1 or 2. (Byte operands can be incremented or decremented by 1 only.) L B Rd 1 Rd, Rd 2 Rd, Rd 4 Rd Adds or subtracts the value 1, 2, or 4 to or from data in a general register. Rd decimal adjust Rd Decimal-adjusts an addition or subtraction result in a general register by referring to the CCR to produce 2-digit 4-bit BCD data. B/W Rd x Rs Rd Performs unsigned multiplication on data in two general registers: either 8 bits x 8 bits 16 bits or 16 bits x 16 bits 32 bits.
ADDX SUBX
INC DEC ADDS SUBS DAA DAS MULXU
MULU
W/L
Rd x Rs Rd Performs unsigned multiplication on data in two general registers: either 16 bits x 16 bits 16 bits or 32 bits x 32 bits 32 bits.
MULU/U
L
Rd x Rs Rd Performs unsigned multiplication on data in two general registers (32 bits x 32 bits upper 32 bits).
MULXS
B/W
Rd x Rs Rd Performs signed multiplication on data in two general registers: either 8 bits x 8 bits 16 bits or 16 bits x 16 bits 32 bits.
MULS
W/L
Rd x Rs Rd Performs signed multiplication on data in two general registers: either 16 bits x 16 bits 16 bits or 32 bits x 32 bits 32 bits.
MULS/U
L
Rd x Rs Rd Performs signed multiplication on data in two general registers (32 bits x 32 bits upper 32 bits).
Rev.2.00 Jun. 28, 2007 Page 41 of 666 REJ09B0311-0200
Section 2 CPU
Instruction DIVXU
Size B/W
Function Rd / Rs Rd Performs unsigned division on data in two general registers: either 16 bits / 8 bits 8-bit quotient and 8-bit remainder or 32 bits / 16 bits 16-bit quotient and 16-bit remainder.
DIVU
W/L
Rd / Rs Rd Performs unsigned division on data in two general registers: either 16 bits / 16 bits 16-bit quotient or 32 bits / 32 bits 32-bit quotient.
DIVXS
B/W
Rd / Rs Rd Performs signed division on data in two general registers: either 16 bits / 8 bits 8-bit quotient and 8-bit remainder or 32 bits / 16 bits 16-bit quotient and 16-bit remainder.
DIVS
W/L
Rd / Rs Rd Performs signed division on data in two general registers: either 16 bits / 16 bits 16-bit quotient or 32 bits / 32 bits 32-bit quotient.
CMP
B/W/L
(EAd) - #IMM, (EAd) - (EAs) Compares data between immediate data, general registers, and memory and stores CCR bits according to the result.
NEG
B/W/L
0 - (EAd) (EAd) Takes the two's complement (arithmetic complement) of the contents of a general register or a memory location.
EXTU
W/L
(EAd) (zero extension) (EAd) Extends the lower 8 or 16 bits of data in a general register or a memory location to word or longword size by padding with 0s. The lower eight bits can be extended to word or longword, or lower 16 bits to longword.
EXTS
W/L
(EAd) (sign extension) (EAd) Extends the lower 8 or 16 bits of data in a general register or a memory location to word size by padding with signs. The lower eight bits can be extended to word or longword, or lower 16 bits to longword.
TAS MAC
B
@ERd - 0, 1 ( of @EAd) Tests memory contents, and sets the most significant bit (bit 7) to 1. (EAd) x (EAs) + MAC MAC Performs signed multiplication on memory contents and adds the result to the MAC.
CLRMAC
0 MAC Clears the MAC to zero.
Rev.2.00 Jun. 28, 2007 Page 42 of 666 REJ09B0311-0200
Section 2 CPU
Instruction LDMAC STMAC
Size
Function Rs MAC Loads data from a general register to the MAC. MAC Rd Stores data from the MAC to a general register.
Table 2.7
Instruction AND
Logic Operation Instructions
Size B/W/L Function (EAd) #IMM (EAd), (EAd) (EAs) (EAd) Performs a logical AND operation on data between immediate data, general registers, and memory.
OR
B/W/L
(EAd) #IMM (EAd), (EAd) (EAs) (EAd) Performs a logical OR operation on data between immediate data, general registers, and memory.
XOR
B/W/L
(EAd) #IMM (EAd), (EAd) (EAs) (EAd) Performs a logical exclusive OR operation on data between immediate data, general registers, and memory.
NOT
B/W/L
(EAd) (EAd) Takes the one's complement (logical complement) of the contents of a general register or a memory location.
Rev.2.00 Jun. 28, 2007 Page 43 of 666 REJ09B0311-0200
Section 2 CPU
Table 2.8
Instruction SHLL SHLR
Shift Operation Instructions
Size B/W/L Function (EAd) (shift) (EAd) Performs a logical shift on the contents of a general register or a memory location. The contents of a general register or a memory location can be shifted by 1, 2, 4, 8, or 16 bits. The contents of a general register can also be shifted by any bits. In this case, the number of bits is specified by 5-bit immediate data or the lower 5 bits of general register contents.
SHAL SHAR
B/W/L
(EAd) (shift) (EAd) Performs an arithmetic shift on the contents of a general register or a memory location. 1-bit or 2-bit shift is possible.
ROTL ROTR ROTXL ROTXR
B/W/L
(EAd) (rotate) (EAd) Rotates the contents of a general register or a memory location. 1-bit or 2-bit rotation is possible.
B/W/L
(EAd) (rotate) (EAd) Rotates the contents of a general register or a memory location with the carry flag. 1-bit or 2-bit rotation is possible.
Table 2.9
Instruction BSET
Bit Manipulation Instructions
Size B Function 1 ( of ) Sets a specified bit in the contents of a general register or a memory location to 1. The bit number is specified by 3-bit immediate data or the lower three bits of a general register.
BSET/cc
B
if cc, 1 ( of ) If the specified condition is satisfied, this instruction sets a specified bit in a memory location to 1. The bit number can be specified by 3-bit immediate data, or by the lower three bits of a general register. The Z flag status can be specified as a condition.
BCLR
B
0 ( of ) Clears a specified bit in the contents of a general register or a memory location to 0. The bit number is specified by 3-bit immediate data or the lower three bits of a general register.
Rev.2.00 Jun. 28, 2007 Page 44 of 666 REJ09B0311-0200
Section 2 CPU
Instruction BCLR/cc
Size B
Function if cc, 0 ( of ) If the specified condition is satisfied, this instruction clears a specified bit in a memory location to 0. The bit number can be specified by 3-bit immediate data, or by the lower three bits of a general register. The Z flag status can be specified as a condition.
BNOT
B
( of ) ( of ) Inverts a specified bit in the contents of a general register or a memory location. The bit number is specified by 3-bit immediate data or the lower three bits of a general register.
BTST
B
( of ) Z Tests a specified bit in the contents of a general register or a memory location and sets or clears the Z flag accordingly. The bit number is specified by 3-bit immediate data or the lower three bits of a general register.
BAND
B
C ( of ) C Logically ANDs the carry flag with a specified bit in the contents of a general register or a memory location and stores the result in the carry flag. The bit number is specified by 3-bit immediate data.
BIAND
B
C [ ( of )] C Logically ANDs the carry flag with the inverse of a specified bit in the contents of a general register or a memory location and stores the result in the carry flag. The bit number is specified by 3-bit immediate data.
BOR
B
C ( of ) C Logically ORs the carry flag with a specified bit in the contents of a general register or a memory location and stores the result in the carry flag. The bit number is specified by 3-bit immediate data.
BIOR
B
C [ ( of )] C Logically ORs the carry flag with the inverse of a specified bit in the contents of a general register or a memory location and stores the result in the carry flag. The bit number is specified by 3-bit immediate data.
BXOR
B
C ( of ) C Logically exclusive-ORs the carry flag with a specified bit in the contents of a general register or a memory location and stores the result in the carry flag. The bit number is specified by 3-bit immediate data.
Rev.2.00 Jun. 28, 2007 Page 45 of 666 REJ09B0311-0200
Section 2 CPU
Instruction BIXOR
Size B
Function C [ ( of )] C Logically exclusive-ORs the carry flag with the inverse of a specified bit in the contents of a general register or a memory location and stores the result in the carry flag. The bit number is specified by 3-bit immediate data.
BLD
B
( of ) C Transfers a specified bit in the contents of a general register or a memory location to the carry flag. The bit number is specified by 3-bit immediate data.
BILD
B
( of ) C Transfers the inverse of a specified bit in the contents of a general register or a memory location to the carry flag. The bit number is specified by 3-bit immediate data.
BST
B
C ( of ) Transfers the carry flag value to a specified bit in the contents of a general register or a memory location. The bit number is specified by 3-bit immediate data.
BSTZ
B
Z ( of ) Transfers the zero flag value to a specified bit in the contents of a memory location. The bit number is specified by 3-bit immediate data.
BIST
B
C ( of ) Transfers the inverse of the carry flag value to a specified bit in the contents of a general register or a memory location. The bit number is specified by 3-bit immediate data.
BISTZ
B
Z ( of ) Transfers the inverse of the zero flag value to a specified bit in the contents of a memory location. The bit number is specified by 3-bit immediate data.
BFLD
B
(EAs) (bit field) Rd Transfers a specified bit field in memory location contents to the lower bits of a specified general register.
BFST
B
Rd (EAd) (bit field) Transfers the lower bits of a specified general register to a specified bit field in memory location contents.
Rev.2.00 Jun. 28, 2007 Page 46 of 666 REJ09B0311-0200
Section 2 CPU
Table 2.10 Branch Instructions
Instruction BRA/BS BRA/BC BSR/BS BSR/BC Bcc BRA/S B Size B Function Tests a specified bit in memory location contents. If the specified condition is satisfied, execution branches to a specified address. Tests a specified bit in memory location contents. If the specified condition is satisfied, execution branches to a subroutine at a specified address. Branches to a specified address if the specified condition is satisfied. Branches unconditionally to a specified address after executing the next instruction. The next instruction should be a 1-word instruction except for the block transfer and branch instructions. Branches unconditionally to a specified address. Branches to a subroutine at a specified address. Branches to a subroutine at a specified address. Returns from a subroutine Returns from a subroutine, restoring data from the stack to general registers.
JMP BSR JSR RTS RTS/L

Rev.2.00 Jun. 28, 2007 Page 47 of 666 REJ09B0311-0200
Section 2 CPU
Table 2.11 System Control Instructions
Instruction TRAPA RTE RTE/L SLEEP LDC Size B/W Function Starts trap-instruction exception handling. Returns from an exception-handling routine. Returns from an exception-handling routine, restoring data from the stack to general registers. Causes a transition to a power-down state. #IMM CCR, (EAs) CCR, #IMM EXR, (EAs) EXR Loads immediate data or the contents of a general register or a memory location to CCR or EXR. Although CCR and EXR are 8-bit registers, word-size transfers are performed between them and memory. The upper eight bits are valid. L STC B/W Rs VBR, Rs SBR Transfers the general register contents to VBR or SBR. CCR (EAd), EXR (EAd) Transfers CCR or EXR contents to a general register or memory. Although CCR and EXR are 8-bit registers, word-size transfers are performed between them and memory. The upper eight bits are valid. L ANDC ORC XORC NOP B B B VBR Rd, SBR Rd Transfers the contents of VBR or SBR to a general register. CCR #IMM CCR, EXR #IMM EXR Logically ANDs the CCR or EXR contents with immediate data. CCR #IMM CCR, EXR #IMM EXR Logically ORs the CCR or EXR contents with immediate data. CCR #IMM CCR, EXR #IMM EXR Logically exclusive-ORs the CCR or EXR contents with immediate data. PC + 2 PC Only increments the program counter.
Rev.2.00 Jun. 28, 2007 Page 48 of 666 REJ09B0311-0200
Section 2 CPU
2.7.3
Basic Instruction Formats
The H8SX CPU instructions consist of 2-byte (1-word) units. An instruction consists of an operation field (op field), a register field (r field), an effective address extension (EA field), and a condition field (cc). Figure 2.14 shows examples of instruction formats.
(1) Operation field only op NOP, RTS, etc.
(2) Operation field and register fields op rm
rn
ADD.B Rn, Rm, etc.
(3) Operation field, register fields, and effective address extension op EA (disp) rn rm MOV.B @(d:16, Rn), Rm, etc.
(4) Operation field, effective address extension, and condition field op cc EA (disp) BRA d:16, etc
Figure 2.14 Instruction Formats * Operation Field Indicates the function of the instruction, the addressing mode, and the operation to be carried out on the operand. The operation field always includes the first four bits of the instruction. Some instructions have two operation fields. * Register Field Specifies a general register. Address registers are specified by 3 bits, data registers by 3 bits or 4 bits. Some instructions have two register fields. Some have no register field. * Effective Address Extension Eight, 16, or 32 bits specifying immediate data, an absolute address, or a displacement. * Condition Field Specifies the branching condition of Bcc instructions.
Rev.2.00 Jun. 28, 2007 Page 49 of 666 REJ09B0311-0200
Section 2 CPU
2.8
Addressing Modes and Effective Address Calculation
The H8SX CPU supports the 11 addressing modes listed in table 2.12. Each instruction uses a subset of these addressing modes. Bit manipulation instructions use register direct, register indirect, or absolute addressing mode to specify an operand, and register direct (BSET, BCLR, BNOT, and BTST instructions) or immediate (3-bit) addressing mode to specify a bit number in the operand. Table 2.12 Addressing Modes
No. Addressing Mode 1 2 3 4 5 Register direct Register indirect Register indirect with displacement Index register indirect with displacement Register indirect with post-increment Register indirect with pre-decrement Register indirect with pre-increment Register indirect with post-decrement 6 7 8 9 10 11 Absolute address Immediate Program-counter relative Program-counter relative with index register Memory indirect Extended memory indirect Symbol Rn @ERn @(d:2,ERn)/@(d:16,ERn)/@(d:32,ERn) @(d:16, RnL.B)/@(d:16,Rn.W)/@(d:16,ERn.L) @(d:32, RnL.B)/@(d:32,Rn.W)/@(d:32,ERn.L) @ERn+ @-ERn @+ERn @ERn- @aa:8/@aa:16/@aa:24/@aa:32 #xx:3/#xx:4/#xx:8/#xx:16/#xx:32 @(d:8,PC)/@(d:16,PC) @(RnL.B,PC)/@(Rn.W,PC)/@(ERn.L,PC) @@aa:8 @@vec:7
Rev.2.00 Jun. 28, 2007 Page 50 of 666 REJ09B0311-0200
Section 2 CPU
2.8.1
Register Direct--Rn
The operand value is the contents of an 8-, 16-, or 32-bit general register which is specified by the register field in the instruction code. R0H to R7H and R0L to R7L can be specified as 8-bit registers. R0 to R7 and E0 to E7 can be specified as 16-bit registers. ER0 to ER7 can be specified as 32-bit registers. 2.8.2 Register Indirect--@ERn
The operand value is the contents of a memory location which is pointed to by the contents of an address register (ERn). ERn is specified by the register field in the instruction code. In advanced mode, if this addressing mode is used in a branch instruction, the lower 24 bits are valid and the upper eight bits are all assumed to be 0 (H'00). 2.8.3 Register Indirect with Displacement--@(d:2, ERn), @(d:16, ERn), or @(d:32, ERn)
The operand value is the contents of a memory location which is pointed to by the sum of the contents of an address register (ERn) and a 16- or 32-bit displacement. ERn is specified by the register field of the instruction code. The displacement is included in the instruction code and the 16-bit displacement is sign-extended when added to ERn. This addressing mode has a short format (@(d:2, ERn)). The short format can be used: when a displacement is 1, 2, or 3 and the operand is byte data, when a displacement is 2, 4, or 6 and the operand is word data, or when a displacement is 4, 8, or 12 and the operand is longword data. 2.8.4 Index Register Indirect with Displacement--@(d:16,RnL.B), @(d:32,RnL.B), @(d:16,Rn.W), @(d:32,Rn.W), @(d:16,ERn.L), or @(d:32,ERn.L)
The operand value is the contents of a memory location which is pointed to by the sum of the following operation result and a 16- or 32-bit displacement: specified bits of the contents of an address register (RnL, Rn, ERn) specified by the register field in the instruction code are zeroextended to 32-bit data and multiplied by 1, 2, or 4. The displacement is included in the instruction code and the 16-bit displacement is sign-extended when added to ERn. If the operand is byte data, ERn is multiplied by 1. If the operand is word or longword data, ERn is multiplied by 2 or 4, respectively.
Rev.2.00 Jun. 28, 2007 Page 51 of 666 REJ09B0311-0200
Section 2 CPU
2.8.5
Register Indirect with Post-Increment, Pre-Decrement, Pre-Increment, or Post-Decrement--@ERn+, @-ERn, @+ERn, or @ERn- Register indirect with post-increment--@ERn+
(1)
The operand value is the contents of a memory location which is pointed to by the contents of an address register (ERn). ERn is specified by the register field in the instruction code. After the memory location is accessed, 1, 2, or 4 is added to the address register contents and the sum is stored in the address register. The value added is 1 for byte access, 2 for word access, or 4 for longword access. (2) Register indirect with pre-decrement--@-ERn
The operand value is the contents of a memory location which is pointed to by the following operation result: the value 1, 2, or 4 is subtracted from the contents of an address register (ERn) which is specified by the register field in the instruction code. After that, the subtraction result is stored in the address register. The value subtracted is 1 for byte access, 2 for word access, or 4 for longword access. (3) Register indirect with pre-increment--@+ERn
The operand value is the contents of a memory location which is pointed to by the following operation result: the value 1, 2, or 4 is added to the contents of an address register (ERn) which is specified by the register field in the instruction code. After that, the sum is stored in the address register. The value added is 1 for byte access, 2 for word access, or 4 for longword access. (4) Register indirect with post-decrement--@ERn-
The operand value is the contents of a memory location which is pointed to by the contents of an address register (ERn). ERn is specified by the register field in the instruction code. After the memory location is accessed, 1, 2, or 4 is subtracted from the address register contents and the subtraction result is stored in the address register. The value subtracted is 1 for byte access, 2 for word access, or 4 for longword access. If the contents of a general register which is also used as an address register is written to memory using this addressing mode, data to be written is the contents of the general register after calculating an effective address. If the same general register is specified in an instruction and two effective addresses are calculated, the contents of the general register after the first calculation of an effective address is used in the second calculation of an effective address.
Rev.2.00 Jun. 28, 2007 Page 52 of 666 REJ09B0311-0200
Section 2 CPU
Example 1: MOV.W R0, @ER0+
When ER0 before execution is H'12345678, H'567A is written at H'12345678. Example 2: MOV.B @ER0+, @ER0+
When ER0 before execution is H'00001000, H'00001000 is read and the contents is written at H'00001001. After execution, ER0 is H'00001002. 2.8.6 Absolute Address--@aa:8, @aa:16, @aa:24, or @aa:32
The operand value is the contents of a memory location which is pointed to by an absolute address included in the instruction code. There are 8-bit (@aa:8), 16-bit (@aa:16), 24-bit (@aa:24), and 32-bit (@aa:32) absolute addresses. To access the data area, the absolute address of eight bits (@aa:8), 16 bits (@aa:16), or 32 bits (@aa:32) is used. For an 8-bit absolute address, the upper 24 bits are specified by SBR. For a 16bit absolute address, the upper 16 bits are sign-extended. A 32-bit absolute address can access the entire address space. To access the program area, the absolute address of 24 bits (@aa:24) or 32 bits (@aa:32) is used. For a 24-bit absolute address, the upper eight bits are all assumed to be 0 (H'00).
Rev.2.00 Jun. 28, 2007 Page 53 of 666 REJ09B0311-0200
Section 2 CPU
Table 2.13 shows the accessible absolute address ranges. Table 2.13 Absolute Address Access Ranges
Absolute Address Data area 8 bits (@aa:8) 16 bits (@aa:16) 32 bits (@aa:32) Program area 24 bits (@aa:24) 32 bits (@aa:32) Normal Mode Middle Mode Advanced Mode Maximum Mode
A consecutive 256-byte area (the upper address bits are set in SBR) H'0000 to H'FFFF H'000000 to H'007FFF, H'FF8000 to H'FFFFFF H'000000 to H'FFFFFF H'00000000 to H'00007FFF, H'FFFF8000 to H'FFFFFFFF H'00000000 to H'FFFFFFFF H'00000000 to H'00FFFFFF H'00000000 to H'00000000 to H'00FFFFFF H'FFFFFFFF
2.8.7
Immediate--#xx:8, #xx:16, or #xx:32
The operand value is 8-bit (#xx:8), 16-bit (#xx:16), or 32-bit (#xx:32) data included in the instruction code. This addressing mode has short formats in which 3- or 4-bit immediate data can be used. When the size of immediate data is less than that of the operand size (byte, word, or longword), the immediate data is zero-extended. The ADDS, SUBS, INC, and DEC instructions contain immediate data implicitly. Some bit manipulation instructions contain 3-bit immediate data in the instruction code, specifying a bit number. The BFLD and BFST instructions contain 8-bit immediate data in its instruction code, specifying bit numbers. The TRAPA instruction contains 2-bit immediate data in its instruction code, specifying a vector address.
Rev.2.00 Jun. 28, 2007 Page 54 of 666 REJ09B0311-0200
Section 2 CPU
2.8.8
Program-Counter Relative--@(d:8, PC) or @(d:16, PC)
This mode is used in the Bcc and BSR instructions. The operand value is a 32-bit branch address, which is the sum of an 8- or 16-bit displacement in the instruction code and the 32-bit address of the PC contents. The 8-bit or 16-bit displacement is sign-extended when added to the PC contents. The PC contents to which the displacement is added is the address of the first byte of the next instruction, so the possible branching range is -126 to +128 bytes (-63 to +64 words) or -32766 to +32768 bytes (-16383 to +16384 words) from the branch instruction. The resulting value should be an even number. In advanced mode, only the lower 24 bits of this branch address are valid; the upper eight bits are all assumed to be 0 (H'00). 2.8.9 Program-Counter Relative with Index Register--@(RnL.B, PC), @(Rn.W, PC), or @(ERn.L, PC)
This mode is used in the Bcc and BSR instructions. The operand value is a 32-bit branch address, which is the sum of the following operation result and the 32-bit address of the PC contents: specified bits of the contents of an address register (RnL, Rn, or ERn) specified by the register field in the instruction code is zero-extended to 32-bit data and multiplied by 2. The PC content to which the displacement is added is the address of the first byte of the next instruction. In advanced mode, only the lower 24 bits of this branch address are valid; the upper eight bits are all assumed to be 0 (H'00). 2.8.10 Memory Indirect--@@aa:8
This mode is used in the JMP and JSR instructions. The operand value is a branch address, which is the content of a memory location pointed to by an 8-bit absolute address in the instruction code. The upper bits of an 8-bit absolute address are all assumed to be 0, so the address range to store a branch address is 0 to 255 (H'0000 to H'00FF in normal mode, H'000000 to H'0000FF in other modes). In normal mode, the memory location is pointed to by word-size data and the branch address is 16 bits long. In other modes, the memory location is pointed to by longword-size data. In middle or advanced mode, the first byte of the longword-size data is assumed to be all 0 (H'00). Note that the top part of the address range is also used as the exception handling vector area. A vector address of an exception handling other than a reset or a CPU address error can be changed by VBR.
Rev.2.00 Jun. 28, 2007 Page 55 of 666 REJ09B0311-0200
Section 2 CPU
Figure 2.15 shows an example of specification of a branch address using this addressing mode.
Specified by @aa:8
Branch address
Specified by @aa:8
Reserved Branch address
(a) Normal Mode
(b) Advanced Mode
Figure 2.15 Branch Address Specification in Memory Indirect Mode 2.8.11 Extended Memory Indirect--@@vec:7
This mode is used in the JMP and JSR instructions. The operand value is a branch address, which is the contents of a memory location pointed to by the following operation result: the sum of 7-bit data in the instruction code and the value of H'80 is multiplied by 2 or 4. The address range to store a branch address is H'0100 to H'01FF in normal mode and H'000200 to H'0003FF in other modes. In assembler notation, an address to store a branch address is specified. In normal mode, the memory location is pointed to by word-size data and the branch address is 16 bits long. In other modes, the memory location is pointed to by longword-size data. In middle or advanced mode, the first byte of the longword-size data is assumed to be all 0 (H'00). 2.8.12 Effective Address Calculation
Tables 2.14 and 2.15 show how effective addresses are calculated in each addressing mode. In normal mode, the upper eight bits of the effective address are ignored in order to generate a 16-bit address.
Rev.2.00 Jun. 28, 2007 Page 56 of 666 REJ09B0311-0200
Section 2 CPU
Table 2.14 Effective Address Calculation for Transfer and Operation Instructions
No. 1 Addressing Mode and Instruction Format Immediate op 2 Register direct op 3 Register indirect op 4 r 31 31 General register contents 15 disp Sign extension 0 31 0 + 0 rm rn 31 General register contents 0 31 0 IMM Effective Address Calculation Effective Address (EA)
Register indirect with 16-bit displacement op r disp
Register indirect with 32-bit displacement op r disp
31 General register contents
0 + disp 31 0
5
Index register indirect with 16-bit displacement
31 Zero extension Contents of general register (RL, R, or ER) 31 15 Sign extension 31 Zero extension Contents of general register (RL, R, or ER) 31 disp
0 1, 2, or 4 x 0 disp 0 1, 2, or 4 x 0 + 31 0 + 31 0
op
r disp
Index register indirect with 32-bit displacement
op
r disp
6
Register indirect with post-increment or post-decrement op r
31 General register contents
0 31 0
Register indirect with pre-increment or pre-decrement op r
31 General register contents
1, 2, or 4 0 1, 2, or 4 31 0
7
8-bit absolute address 31 op aa SBR 7 aa 0 31 0
16-bit absolute address op aa 31 Sign extension 15 aa 0 31 0
32-bit absolute address op aa
31 aa
0
31
0
Rev.2.00 Jun. 28, 2007 Page 57 of 666 REJ09B0311-0200
Section 2 CPU
Table 2.15 Effective Address Calculation for Branch Instructions
No. 1 Addressing Mode and Instruction Format Register indirect op 2 r Effective Address Calculation 31 General register contents 0 Effective Address (EA) 31 0
Program-counter relative with 8-bit displacement 31 PC contents 31 op disp Sign extension 7 disp 0 + 0 31 0
Program-counter relative with 16-bit displacement 31 op disp 31 PC contents 15 Sign extension 0 31 0 disp + 0
3
Program-counter relative with index register
31
op
r
0 Zero extension Contents of general register (RL, R, or ER) x 2 + 0 31 PC contents Zero 31extension23
31
0
4
24-bit absolute address op aa
0 aa
31
0
32-bit absolute address op aa 31 aa 0 31 0
5
Memory indirect 31 op aa 31 Memory contents Zero extension 7 aa 0 31 0 0
6
Extended memory indirect 31 op vec Zero extension 7 1 0 vec 2 or 4 x 0 0 Memory contents 31 0
31 31
2.8.13
MOVA Instruction
The MOVA Instruction stores the effective address into the general register. 1. Obtains data in the addressing mode of No.2 in table 2.14. 2. By using this data as the index instead of the general register in row No.5 in table 14.2, the effective address calculation is executed, and the outcome is stored in the general register. For details, see the H8SX Family Software Manual.
Rev.2.00 Jun. 28, 2007 Page 58 of 666 REJ09B0311-0200
Section 2 CPU
2.9
Processing States
The H8SX CPU has five main processing states: the reset state, exception-handling state, program execution state, bus-released state, and program stop state. Figure 2.16 indicates the state transitions. * Reset state In this state the CPU and internal peripheral modules are all initialized and stopped. When the RES input goes low, all current processing stops and the CPU enters the reset state. All interrupts are masked in the reset state. Reset exception handling starts when the RES signal changes from low to high. For details, see section 4, Exception Handling. The reset state can also be entered by a watchdog timer overflow when available. * Exception-handling state The exception-handling state is a transient state that occurs when the CPU alters the normal processing flow due to activation of an exception source, such as, a reset, trace, interrupt, or trap instruction. The CPU fetches a start address (vector) from the exception handling vector table and branches to that address. For further details, see section 4, Exception Handling. * Program execution state In this state the CPU executes program instructions in sequence. * Bus-released state The bus-released state occurs when the bus has been released in response to a bus request from a bus master other than the CPU. While the bus is released, the CPU halts operations. * Program stop state This is a power-down state in which the CPU stops operating. The program stop state occurs when a SLEEP instruction is executed or the CPU enters hardware standby mode. For details, see section 18, Power-Down States.
Rev.2.00 Jun. 28, 2007 Page 59 of 666 REJ09B0311-0200
Section 2 CPU
Reset state* RES = high
RES = low Bus-released state
Exception-handling state Request for exception handling
Interrupt Bus request request End of exception handling End of bus request
Bus request
End of bus request
Program execution state Note: *
Program stop state SLEEP instruction
A transition to the reset state occurs whenever the RES signal goes low. A transition can also be made to the reset state when the watchdog timer overflows.
Figure 2.16 State Transitions
Rev.2.00 Jun. 28, 2007 Page 60 of 666 REJ09B0311-0200
Section 3 MCU Operating Modes
Section 3 MCU Operating Modes
3.1 Operating Mode Selection
This LSI has two operating modes (modes 4 and 5). The operating mode is selected by the setting of mode pins (MD2 to MD0). Table 3.1 lists MCU operating mode settings. Table 3.1 MCU Operating Mode Settings
CPU Operating Mode Advanced External Data Bus Width Default Max. 16 bits 8 bits 16 bits 16 bits
MCU Operating Mode MD2 4 5 1 1
MD1 0 0
MD0 0 1
Address Space
Description
On-Chip ROM Disabled Disabled
16 Mbytes On-chip ROM disabled extended mode
In this LSI, advanced mode for the CPU operating mode, 16 Mbytes for the address space, and eight or 16 bits for the default external bus width are available. In modes 4 and 5, which are external extended modes, it is possible to access the external memory and devices. In external extended mode, the external address space can be designated as 8-bit or 16-bit address space for each area by the bus controller after starting program execution. If 16-bit address space is designated for any one area, the bus mode switches to 16 bits. If 8-bit address space is designated for all areas, the bus mode switches to 8 bits.
Rev.2.00 Jun. 28, 2007 Page 61 of 666 REJ09B0311-0200
Section 3 MCU Operating Modes
3.2
Register Descriptions
The following registers are related to the operating mode setting. * Mode control register (MDCR) * System control register (SYSCR) 3.2.1 Mode Control Register (MDCR)
MDCR indicates the current operating mode. When MDCR is read, the input levels in pins MD2 to MD0 are latched. These latches are released by a reset.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 0 R 7 0 R 14 1 R 6 1 R 13 0 R 5 0 R 12 1 R 4 1 R 11 0 R 3 0 R 10 MDS2 Undefined* R 2 Undefined* R 9 MDS1 Undefined* R 1 Undefined* R 8 MDS0 Undefined* R 0 Undefined* R
Note: * Determined by pins MD2 to MD0.
Bit 15 14 13 12 11 10 9 8
Bit Name Initial Value R/W MDS2 MDS1 MDS0 0 1 0 1 0 Undefined* Undefined* Undefined* R R R R R R R R
Descriptions Reserved These are read-only bits and cannot be modified.
Mode Select 2 to 0 These bits indicate the operating mode selected by the mode pins (MD2 to MD0) (see table 3.2). When MDCR is read, the signal levels input on pins MD2 to MD0 are latched into these bits. These latches are released by a reset.
Rev.2.00 Jun. 28, 2007 Page 62 of 666 REJ09B0311-0200
Section 3 MCU Operating Modes
Bit 7 6 5 4 3 2 1 0 Note: *
Bit Name Initial Value R/W 0 1 0 1 0 Undefined* Undefined* Undefined* R R R R R R R R
Descriptions Reserved These are read-only bits and cannot be modified.
Determined by pins MD2 to MD0.
Table 3.2
Settings of Bits MSD2 to MSD0
MDCR MD2 1 1 MD1 0 0 MD0 0 1 MDS2 0 0 MDS1 1 0 MDS0 0 1
MCU Operating Mode 4 5
Rev.2.00 Jun. 28, 2007 Page 63 of 666 REJ09B0311-0200
Section 3 MCU Operating Modes
3.2.2
System Control Register (SYSCR)
SYSCR controls MAC saturation operation, selects bus width mode for instruction fetch, sets external bus mode, enables/disables the on-chip RAM, and selects the DTC address mode.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 1 R/W 7 0 R/W 14 1 R/W 6 0 R/W 13 MACS 0 R/W 5 0 R/W 12 1 R/W 4 0 R/W 11 FETCHMD 0 R/W 3 0 R/W 10 0 R/W 2 0 R/W 9 EXPE Undefined* R/W 1 DTCMD 1 R/W 8 RAME 1 R/W 0 1 R/W
Note: * The initial value depends on the startup mode.
Bit 15, 14
Bit Name
Initial Value All 1
R/W R/W
Descriptions Reserved These bits are always read as 1. The write value should always be 1.
13
MACS
0
R/W
MAC Saturation Operation Control Selects either saturation operation or non-saturation operation for the MAC instruction. 0: MAC instruction is non-saturation operation 1: MAC instruction is saturation operation
12
1
R/W
Reserved This bit is always read as 1. The write value should always be 1.
11
FETCHMD 0
R/W
Instruction Fetch Mode Select The H8SX CPU has two modes for instruction fetch: 16bit and 32-bit modes. It is recommended that the mode should be set according to the bus width of the memory in 1 which the program is stored* . 0: 32-bit width 1: 16-bit width
Rev.2.00 Jun. 28, 2007 Page 64 of 666 REJ09B0311-0200
Section 3 MCU Operating Modes
Bit 10
Bit Name
Initial Value 0
R/W R/W
Descriptions Reserved This bit is always read as 0. The write value should always be 0.
9
EXPE
Undefined*
2
R/W
External Bus Mode Enable Selects external bus mode. In external extended mode, this bit is fixed at 1 and cannot be changed. In singlechip mode, the initial value of this bit is 0, and can be read from or written to. When writing 0 to this bit after reading EXPE = 1, an external bus cycle should not be executed. The external bus cycle may be carried out in parallel with the internal bus cycle depending on the setting of the write data buffer function. 0: External bus disabled 1: External bus enabled
8
RAME
1
R/W
RAM Enable Enables or disables the on-chip RAM. This bit is initialized when the reset state is released. Do not write 0 during access to the on-chip RAM. 0: On-chip RAM disabled 1: On-chip RAM enabled
7 to 2
All 0
R/W
Reserved These bits are always read as 0. The write value should always be 0.
1
DTCMD
1
R/W
DTC Mode Select Selects DTC operation mode. 0: DTC is in full-address mode 1: DTC is in short address mode
0
1
R/W
Reserved This bit is always read as 1. The write value should always be 1.
Notes: 1. For details, see section 2.3, Instruction Fetch. 2. The initial value depends on the startup mode. In operating modes 4 and 5, which are external extended modes, EXPE = 1.
Rev.2.00 Jun. 28, 2007 Page 65 of 666 REJ09B0311-0200
Section 3 MCU Operating Modes
3.3
3.3.1
Operating Mode Descriptions
Mode 4
The CPU operating mode is advanced mode in which the address space is 16 Mbytes, and the onchip ROM is disabled. The initial bus mode immediately after a reset is 16 bits, with 16-bit access to all areas. Ports D, E, and F function as an address bus, ports H and I function as a data bus, and parts of ports A and B function as bus control signals. However, if all areas are designated as an 8-bit access space by the bus controller, the bus mode switches to 8 bits, and only port H functions as a data bus. 3.3.2 Mode 5
The CPU operating mode is advanced mode in which the address space is 16 Mbytes, and the onchip ROM is disabled. The initial bus mode immediately after a reset is 8 bits, with 8-bit access to all areas. Ports D, E, and F function as an address bus, port H functions as a data bus, and parts of ports A and B function as bus control signals. However, if all areas are designated as a 16-bit access space by the bus controller, the bus mode switches to 16 bits, and ports H and I function as a data bus.
Rev.2.00 Jun. 28, 2007 Page 66 of 666 REJ09B0311-0200
Section 3 MCU Operating Modes
3.3.3
Pin Functions
Table 3.3 lists the pin functions in each operating mode. Table 3.3 Pin Functions in Each Operating Mode (Advanced Mode)
Port Port A PA7 PA6, PA4 PA2 to PA0 Port B PB3 to 1 PB0 Port D Port E Port F PF7 to PF5 PF4 to PF0 Port H Port I Mode 4 P/C* P/C* P*/C P*/C P/C* A A P*/A A D P/D* Mode 5 P/C* P/C* P*/C P*/C P/C* A A P*/A A D P*/D
[Legend] P: I/O port A: Address bus output D: Data bus input/output C: Control signals, clock input/output *: Immediately after a reset
Rev.2.00 Jun. 28, 2007 Page 67 of 666 REJ09B0311-0200
Section 3 MCU Operating Modes
3.4
3.4.1
Address Map
Address Map (Advanced Mode)
Figure 3.1 shows the address map.
Modes 4, 5 On-chip ROM disabled extended mode (Advanced mode) H'000000
External address space
H'FD9000
(Access prohibited space) External address space (Access prohibited space) On-chip RAM/ external address space* External address space
H'FDC000 H'FF0000 H'FF6000
H'FFC000
H'FFEA00 H'FFFF00 H'FFFF20 H'FFFFFF Note: *
On-chip I/O registers External address space On-chip I/O registers
This area is specified as the external address space by clearing the RAME bit in SYSCR to 0.
Figure 3.1 Address Map (Advanced Mode)
Rev.2.00 Jun. 28, 2007 Page 68 of 666 REJ09B0311-0200
Section 4 Exception Handling
Section 4 Exception Handling
4.1 Exception Handling Types and Priority
As table 4.1 indicates, exception handling is caused by a reset, a trace, an address error, an interrupt, a trap instruction, a sleep instruction, and an illegal instruction (general illegal instruction or slot illegal instruction). Exception handling is prioritized as shown in table 4.1. If two or more exceptions occur simultaneously, they are accepted and processed in order of priority. Exception sources, the stack structure, and operation of the CPU vary depending on the interrupt control mode. For details on the interrupt control mode, see section 5, Interrupt Controller. Table 4.1
Priority High
Exception Types and Priority
Exception Type Reset Exception Handling Start Timing Exception handling starts at the timing of level change from low to high on the RES pin, or when the watchdog timer overflows. The CPU enters the reset state when the RES pin is low. Exception handling starts when an undefined code is executed. Exception handling starts after execution of the current instruction or exception handling, if the trace (T) bit in EXR is set to 1. After an address error has occurred, exception handling starts on completion of instruction execution. Exception handling starts after execution of the current instruction or exception handling, if an interrupt request has occurred.*2 Exception handling starts by execution of a sleep instruction (SLEEP), if the SSBY bit in SBYCR is set to 0 and the SLPIE bit in SBYCR is set to 1. Exception handling starts by execution of a trap instruction (TRAPA).
Illegal instruction Trace*1
Address error Interrupt
Sleep instruction
Trap instruction*3 Low
Notes: 1. Traces are enabled only in interrupt control mode 2. Trace exception handling is not executed after execution of an RTE instruction. 2. Interrupt detection is not performed on completion of ANDC, ORC, XORC, or LDC instruction execution, or on completion of reset exception handling. 3. Trap instruction exception handling requests and sleep instruction exception handling requests are accepted at all times in program execution state.
Rev.2.00 Jun. 28, 2007 Page 69 of 666 REJ09B0311-0200
Section 4 Exception Handling
4.2
Exception Sources and Exception Handling Vector Table
Different vector table address offsets are assigned to different exception sources. The vector table addresses are calculated from the contents of the vector base register (VBR) and vector table address offset of the vector number. The start address of the exception service routine is fetched from the exception handling vector table indicated by this vector table address. Table 4.2 shows the correspondence between the exception sources and vector table address offsets. Table 4.3 shows the calculation method of exception handling vector table addresses. Since the usable modes differ depending on the product, for details on the available modes, see section 3, MCU Operating Modes. Table 4.2 Exception Handling Vector Table
Vector Table Address Offset*1 Exception Source Reset Reserved for system use Vector Number 0 1 2 3 Illegal instruction Trace Reserved for system use Interrupt (NMI) Trap instruction (#0) (#1) (#2) (#3) CPU address error DMA address error*
3
Normal Mode*
2
Advanced, Middle*2, 2 Maximum* Modes H'0000 to H'0003 H'0004 to H'0007 H'0008 to H'000B H'000C to H'000F H'0010 to H'0013 H'0014 to H'0017 H'0018 to H'001B H'001C to H'001F H'0020 to H'0023 H'0024 to H'0027 H'0028 to H'002B H'002C to H'002F H'0030 to H'0033 H'0034 to H'0037 H'0038 to H'003B H'0044 to H'0047 H'0048 to H'004B
H'0000 to H'0001 H'0002 to H'0003 H'0004 to H'0005 H'0006 to H'0007 H'0008 to H'0009 H'000A to H'000B H'000C to H'000D H'000E to H'000F H'0010 to H'0011 H'0012 to H'0013 H'0014 to H'0015 H'0016 to H'0017 H'0018 to H'0019 H'001A to H'001B H'001C to H'001D H'0022 to H'0023 H'0024 to H'0025
4 5 6 7 8 9 10 11 12 13 14 17 18
Reserved for system use
Sleep instruction
Rev.2.00 Jun. 28, 2007 Page 70 of 666 REJ09B0311-0200
Section 4 Exception Handling
Vector Table Address Offset*1 Exception Source Reserved for system use Vector Number 19 23 24 63 64 65 66 67 68 69 70 71 72 73 74 75 76 79 80 255 Normal Mode*
2
Advanced, Middle*2, Maximum*2 Modes H'004C to H'004F H'005C to H'005F H'0060 to H'0063 H'00FC to H'00FF H'0100 to H'0103 H'0104 to H'0107 H'0108 to H'010B H'010C to H'010F H'0110 to H'0113 H'0114 to H'0117 H'0118 to H'011B H'011C to H'011F H'0120 to H'0123 H'0124 to H'0127 H'0128 to H'012B H'012C to H'012F H'0130 to H'0133 H'013C to H'013F H'0140 to H'0143 H'03FC to H'03FF
H'0026 to H'0027 H'002E to H'002F H'0030 to H'0031 H'007E to H'007F H'0080 to H'0081 H'0082 to H'0083 H'0084 to H'0085 H'0086 to H'0087 H'0088 to H'0089 H'008A to H'008B H'008C to H'008D H'008E to H'008F H'0090 to H'0091 H'0092 to H'0093 H'0094 to H'0095 H'0096 to H'0097 H'0098 to H'0099 H'009E to H'009F H'00A0 to H'00A1 H'01FE to H'01FF
User area (open space)
External interrupt
IRQ0 IRQ1 IRQ2 IRQ3 IRQ4 IRQ5 IRQ6 IRQ7 IRQ8 IRQ9 IRQ10 IRQ11
Reserved for system use
Internal interrupt*4
Notes: 1. 2. 3. 4.
Lower 16 bits of the address. Not available in this LSI. A DMA address error is generated by the DTC. For details of internal interrupt vectors, see section 5.5, Interrupt Exception Handling Vector Table.
Rev.2.00 Jun. 28, 2007 Page 71 of 666 REJ09B0311-0200
Section 4 Exception Handling
Table 4.3
Calculation Method of Exception Handling Vector Table Address
Calculation Method of Vector Table Address Vector table address = (vector table address offset) Vector table address = VBR + (vector table address offset)
Exception Source Reset, CPU address error Other than above [Legend] VBR: Vector base register Vector table address offset:
See table 4.2.
4.3
Reset
A reset has priority over any other exception. When the RES pin goes low, all processing halts and this LSI enters the reset state. To ensure that this LSI is reset, hold the RES pin low for at least 20 ms with the STBY pin driven high when the power is turned on. When operation is in progress, hold the RES pin low for at least 20 cycles. The chip can also be reset by overflow of the watchdog timer. For details, see section 12, Watchdog Timer (WDT). A reset initializes the internal state of the CPU and the registers of the on-chip peripheral modules. The interrupt control mode is 0 immediately after a reset. 4.3.1 Reset Exception Handling
When the RES pin goes high after being held low for the necessary time, this LSI starts reset exception handling as follows: 1. The internal state of the CPU and the registers of the on-chip peripheral modules are initialized, VBR is cleared to H'00000000, the T bit is cleared to 0 in EXR, and the I bits are set to 1 in EXR and CCR. 2. The reset exception handling vector address is read and transferred to the PC, and program execution starts from the address indicated by the PC. Figures 4.1 and 4.2 show examples of the reset sequence.
Rev.2.00 Jun. 28, 2007 Page 72 of 666 REJ09B0311-0200
Section 4 Exception Handling
4.3.2
Interrupts after Reset
If an interrupt is accepted after a reset but before the stack pointer (SP) is initialized, the PC and CCR will not be saved correctly, leading to a program crash. To prevent this, all interrupt requests, including NMI, are disabled immediately after a reset. Since the first instruction of a program is always executed immediately after the reset state ends, make sure that this instruction initializes the stack pointer (example: MOV.L #xx: 32, SP). 4.3.3 On-Chip Peripheral Functions after Reset Release
After the reset state is released, MSTPCRA and MSTPCRB are initialized to H'0FFF and H'FFFF, respectively, and all modules except the DTC enter module stop state. Consequently, on-chip peripheral module registers cannot be read or written to. Register reading and writing is enabled when module stop state is canceled.
First Internal instruction operation prefetch
Vector fetch I
RES Internal address bus Internal read signal Internal write signal Internal data bus (1) (2) (3) (4) (2) (1) (3)
High
(4)
Reset exception handling vector address (when reset, (1) = H'000000) Start address (contents of reset exception handling vector address) Start address ((3) = (2)) First instruction in the exception handling routine
Figure 4.1 Reset Sequence (On-chip ROM Enabled Advanced Mode)
Rev.2.00 Jun. 28, 2007 Page 73 of 666 REJ09B0311-0200
Section 4 Exception Handling
Vector fetch * B *
Internal First instruction operation prefetch *
RES
Address bus
(1)
(3)
(5)
RD HWR, LWR D15 to D0 (2)
High
(4) (6)
(1)(3) Reset exception handling vector address (when reset, (1) = H'000000, (3) = H'000002) (2)(4) Start address (contents of reset exception handling vector address) (5) Start address ((5) = (2)(4)) (6) First instruction in the exception handling routine Note: * Seven program wait cycles are inserted.
Figure 4.2 Reset Sequence (16-Bit External Access in On-chip ROM Disabled Advanced Mode)
Rev.2.00 Jun. 28, 2007 Page 74 of 666 REJ09B0311-0200
Section 4 Exception Handling
4.4
Traces Exception Handling
Traces are enabled in interrupt control mode 2. Trace mode is not activated in interrupt control mode 0, irrespective of the state of the T bit. Before changing interrupt control modes, the T bit must be cleared. For details on interrupt control modes, see section 5, Interrupt Controller. If the T bit in EXR is set to 1, trace mode is activated. In trace mode, a trace exception occurs on completion of each instruction. Trace mode is not affected by interrupt masking by CCR. Table 4.4 shows the state of CCR and EXR after execution of trace exception handling. Trace mode is canceled by clearing the T bit in EXR to 0 during the trace exception handling. However, the T bit saved on the stack retains its value of 1, and when control is returned from the trace exception handling routine by the RTE instruction, trace mode resumes. Trace exception handling is not carried out after execution of the RTE instruction. Interrupts are accepted even within the trace exception handling routine. Table 4.4 Status of CCR and EXR after Trace Exception Handling
CCR Interrupt Control Mode 0 2 I UI I2 to I0 EXR T
Trace exception handling cannot be used. 1 0
[Legend] 1: Set to 1 0: Cleared to 0 : Retains the previous value.
Rev.2.00 Jun. 28, 2007 Page 75 of 666 REJ09B0311-0200
Section 4 Exception Handling
4.5
4.5.1
Address Error
Address Error Source
Instruction fetch, stack operation, or data read/write shown in table 4.5 may cause an address error. Table 4.5 Bus Cycle and Address Error
Bus Cycle Type Bus Master Description Fetches instructions from even addresses Fetches instructions from odd addresses Fetches instructions from areas other than on-chip peripheral module space*1 Address Error No (normal) Occurs No (normal)
Instruction CPU fetch
Fetches instructions from on-chip peripheral module Occurs 1 space* Fetches instructions from external memory space in Occurs single-chip mode Fetches instructions from access prohibited area.*2 Stack operation CPU Occurs
Accesses stack when the stack pointer value is even No (normal) address Accesses stack when the stack pointer value is odd Occurs No (normal) No (normal) Occurs Occurs No (normal) No (normal) Occurs Occurs
Data read/write
CPU
Accesses word data from even addresses Accesses word data from odd addresses Accesses external memory space in single-chip mode Accesses to access prohibited area*2
Data read/write
DTC
Accesses word data from even addresses Accesses word data from odd addresses Accesses external memory space in single-chip mode Accesses to access prohibited area*
2
Notes: 1. For on-chip peripheral module space, see section 6, Bus Controller (BSC). 2. For the access-prohibited area, see figure 3.1, Address Map (Advanced Mode) in section 3.4, Address Map.
Rev.2.00 Jun. 28, 2007 Page 76 of 666 REJ09B0311-0200
Section 4 Exception Handling
4.5.2
Address Error Exception Handling
When an address error occurs, address error exception handling starts after the bus cycle causing the address error ends and current instruction execution completes. The address error exception handling is as follows: 1. The contents of PC, CCR, and EXR are saved in the stack. 2. The interrupt mask bit is updated and the T bit is cleared to 0. 3. An exception handling vector table address corresponding to the address error is generated, the start address of the exception service routine is loaded from the vector table to PC, and program execution starts from that address. Even though an address error occurs during a transition to an address error exception handling, the address error is not accepted. This prevents an address error from occurring due to stacking for exception handling, thereby preventing infinitive stacking. If the SP contents are not a multiple of 2 when an address error exception handling occurs, the stacked values (PC, CCR, and EXR) are undefined. When an address error occurs, the following is performed to halt the DTC. * The ERR bit in DTCCR is set to 1. Table 4.6 shows the state of CCR and EXR after execution of the address error exception handling. Table 4.6 Status of CCR and EXR after Address Error Exception Handling
CCR Interrupt Control Mode 0 2 I 1 1 UI T 0 EXR I2 to I0 7
[Legend] 1: Set to 1 0: Cleared to 0 : Retains the previous value.
Rev.2.00 Jun. 28, 2007 Page 77 of 666 REJ09B0311-0200
Section 4 Exception Handling
4.6
4.6.1
Interrupts
Interrupt Sources
Interrupt sources are NMI, IRQ0 to IRQ11, and on-chip peripheral modules, as shown in table 4.7. Table 4.7
Type NMI IRQ0 to IRQ11 On-chip peripheral module
Interrupt Sources
Source NMI pin (external input) Pins IRQ0 to IRQ11 (external input) Watchdog timer (WDT) A/D converter 16-bit timer pulse unit (TPU) 8-bit timer (TMR) Serial communications interface (SCI) Number of Sources 1 12 1 1 26 12 16
Different vector numbers and vector table offsets are assigned to different interrupt sources. For vector number and vector table offset, see table 5.2, Interrupt Sources, Vector Address Offsets, and Interrupt Priority in section 5, Interrupt Controller. 4.6.2 Interrupt Exception Handling
Interrupts are controlled by the interrupt controller. The interrupt controller has two interrupt control modes and can assign interrupts other than NMI to eight priority/mask levels to enable multiple-interrupt control. The source to start interrupt exception handling and the vector address differ depending on the product. For details, see section 5, Interrupt Controller. The interrupt exception handling is as follows: 1. The contents of PC, CCR, and EXR are saved in the stack. 2. The interrupt mask bit is updated and the T bit is cleared to 0. 3. An exception handling vector table address corresponding to the interrupt source is generated, the start address of the exception service routine is loaded from the vector table to PC, and program execution starts from that address.
Rev.2.00 Jun. 28, 2007 Page 78 of 666 REJ09B0311-0200
Section 4 Exception Handling
4.7
Instruction Exception Handling
There are three instructions that cause exception handling: trap instruction, sleep instruction, and illegal instruction. 4.7.1 Trap Instruction Exception Handling
Trap instruction exception handling starts when a TRAPA instruction is executed. Trap instruction exception handling can be executed at all times in the program execution state. The trap instruction exception handling is as follows: 1. The contents of PC, CCR, and EXR are saved in the stack. 2. The interrupt mask bit is updated and the T bit is cleared to 0. 3. An exception handling vector table address corresponding to the vector number specified in the TRAPA instruction is generated, the start address of the exception service routine is loaded from the vector table to PC, and program execution starts from that address. A start address is read from the vector table corresponding to a vector number from 0 to 3, as specified in the instruction code. Table 4.8 shows the state of CCR and EXR after execution of trap instruction exception handling. Table 4.8 Status of CCR and EXR after Trap Instruction Exception Handling
CCR Interrupt Control Mode 0 2 I 1 1 UI T 0 EXR I2 to I0
[Legend] 1: Set to 1 0: Cleared to 0 : Retains the previous value.
Rev.2.00 Jun. 28, 2007 Page 79 of 666 REJ09B0311-0200
Section 4 Exception Handling
4.7.2
Sleep Instruction Exception Handling
The sleep instruction exception handling starts when a sleep instruction is executed with the SSBY bit in SBYCR set to 0 and the SLPIE bit in SBYCR set to 1. The sleep instruction exception handling can always be executed in the program execution state. In the exception handling, the CPU operates as follows. 1. The contents of PC, CCR, and EXR are saved in the stack. 2. The interrupt mask bit is updated and the T bit is cleared to 0. 3. An exception handling vector table address corresponding to the vector number specified in the SLEEP instruction is generated, the start address of the exception service routine is loaded from the vector table to PC, and program execution starts from that address. Bus masters other than the CPU may gain the bus mastership after a sleep instruction has been executed. In such cases the sleep instruction will be started when the transactions of a bus master other than the CPU has been completed and the CPU has gained the bus mastership. Table 4.9 shows the state of CCR and EXR after execution of sleep instruction exception handling. Table 4.9 Status of CCR and EXR after Sleep Instruction Exception Handling
CCR Interrupt Control Mode 0 2 I 1 1 UI T 0 EXR I2 to I0 7
[Legend] 1: Set to 1 0: Cleared to 0 : Retains the previous value.
Rev.2.00 Jun. 28, 2007 Page 80 of 666 REJ09B0311-0200
Section 4 Exception Handling
4.7.3
Exception Handling by Illegal Instruction
The illegal instructions are general illegal instructions and slot illegal instructions. The exception handling by the general illegal instruction starts when an undefined code is executed. The exception handling by the slot illegal instruction starts when a particular instruction (e.g. its code length is two words or more, or it changes the PC contents) at a delay slot (immediately after a delayed branch instruction) is executed. The exception handling by the general illegal instruction and slot illegal instruction is always executable in the program execution state. The exception handling is as follows: 1. The contents of PC, CCR, and EXR are saved in the stack. 2. The interrupt mask bit is updated and the T bit is cleared to 0. 3. An exception handling vector table address corresponding to the occurred exception is generated, the start address of the exception service routine is loaded from the vector table to PC, and program execution starts from that address. Table 4.10 shows the state of CCR and EXR after execution of illegal instruction exception handling. Table 4.10 Status of CCR and EXR after Illegal Instruction Exception Handling
CCR Interrupt Control Mode 0 2 I 1 1 UI T 0 EXR I2 to I0
[Legend] 1: Set to 1 0: Cleared to 0 : Retains the previous value.
Rev.2.00 Jun. 28, 2007 Page 81 of 666 REJ09B0311-0200
Section 4 Exception Handling
4.8
Stack Status after Exception Handling
Figure 4.3 shows the stack after completion of exception handling.
Advanced mode
SP
EXR Reserved*
SP
CCR PC (24 bits)
CCR PC (24 bits)
Interrupt control mode 0 Note: * Ignored on return.
Interrupt control mode 2
Figure 4.3 Stack Status after Exception Handling
Rev.2.00 Jun. 28, 2007 Page 82 of 666 REJ09B0311-0200
Section 4 Exception Handling
4.9
Usage Note
When performing stack-manipulating access, this LSI assumes that the lowest address bit is 0. The stack should always be accessed by a word transfer instruction or a longword transfer instruction, and the value of the stack pointer (SP: ER7) should always be kept even. Use the following instructions to save registers:
PUSH.W PUSH.L Rn ERn (or MOV.W Rn, @-SP) (or MOV.L ERn, @-SP)
Use the following instructions to restore registers:
POP.W POP.L Rn ERn (or MOV.W @SP+, Rn) (or MOV.L @SP+, ERn)
Performing stack manipulation while SP is set to an odd value leads to an address error. Figure 4.4 shows an example of operation when the SP value is odd.
Address
CCR SP PC
SP
R1L
H'FFFEFA H'FFFEFB
PC
H'FFFEFC H'FFFEFD H'FFFEFE
SP
H'FFFEFF
TRAPA instruction executed SP set to H'FFFEFF
MOV.B R1L, @-ER7 executed Contents of CCR lost
Data saved above SP (Address error occurred)
[Legend] CCR : PC : R1L : SP : Condition code register Program counter General register R1L Stack pointer
Note: This diagram illustrates an example in which the interrupt control mode is 0, in advanced mode.
Figure 4.4 Operation when SP Value Is Odd
Rev.2.00 Jun. 28, 2007 Page 83 of 666 REJ09B0311-0200
Section 4 Exception Handling
Rev.2.00 Jun. 28, 2007 Page 84 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
Section 5 Interrupt Controller
5.1 Features
* Two interrupt control modes Any of two interrupt control modes can be set by means of bits INTM1 and INTM0 in the interrupt control register (INTCR). * Priority can be assigned by the interrupt priority register (IPR) IPR provides for setting interrupt priory. Eight levels can be set for each module for all interrupts except for the interrupt requests listed below. The following seven interrupt requests are given priority of 8, therefore they are accepted at all times. NMI Illegal instructions Trace Trap instructions CPU address error DMA address error (occurred in the DTC) Sleep instruction * Independent vector addresses All interrupt sources are assigned independent vector addresses, making it unnecessary for the source to be identified in the interrupt handling routine. * Thirteen external interrupts NMI is the highest-priority interrupt, and is accepted at all times. Rising edge or falling edge detection can be selected for NMI. Falling edge, rising edge, or both edge detection, or level sensing, can be selected for IRQ11 to IRQ0. * DTC control DTC can be activated by means of interrupts. * CPU priority control function The priority levels can be assigned to the CPU and DTC. The priority level of the CPU can be automatically assigned on an exception generation. Priority can be given to the CPU interrupt exception handling over that of the DTC transfer.
Rev.2.00 Jun. 28, 2007 Page 85 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
A block diagram of the interrupt controller is shown in figure 5.1.
INTM1, INTM0 INTCR NMIEG
IPR I I2 to I0 CPU interrupt request CPU vector Priority determination
CPU
CCR EXR
NMI input IRQ input
NMI input unit IRQ input unit ISR
ISCR
IER
SSIER
Internal interrupt sources WOVI
Source selecter
CPU priority DTC activation request
DTCER DTCCR CPUPCR DTC priority control
DTC
DTC vector Activation request clear signal
DTC priority Interrupt controller [Legend] INTCR: Interrupt control register CPUPCR: CPU priority control register IRQ sense control register ISCR: IRQ enable register IER: IRQ status register ISR: SSIER: IPR: DTCER: DTCCR:
Software standby release IRQ enable register Interrupt priority register DTC enable register DTC control register
Figure 5.1 Block Diagram of Interrupt Controller
Rev.2.00 Jun. 28, 2007 Page 86 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
5.2
Input/Output Pins
Table 5.1 shows the pin configuration of the interrupt controller. Table 5.1
Name NMI IRQ11 to IRQ0
Pin Configuration
I/O Input Input Function Nonmaskable External Interrupt Rising or falling edge can be selected. Maskable External Interrupts Rising, falling, or both edges, or level sensing, can be selected.
5.3
Register Descriptions
The interrupt controller has the following registers. * Interrupt control register (INTCR) * CPU priority control register (CPUPCR) * Interrupt priority registers A to C, E to H, K, and L (IPRA to IPRC, IPRE to IPRH, IPRK, and IPRL) * IRQ enable register (IER) * IRQ sense control registers H and L (ISCRH, ISCRL) * IRQ status register (ISR) * Software standby release IRQ enable register (SSIER)
Rev.2.00 Jun. 28, 2007 Page 87 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
5.3.1
Interrupt Control Register (INTCR)
INTCR selects the interrupt control mode, and the detected edge for NMI.
Bit Bit Name Initial Value R/W 7 0 R 6 0 R 5 INTM1 0 R/W 4 INTM0 0 R/W 3 NMIEG 0 R/W 2 0 R 1 0 R 0 0 R
Bit 7, 6 5 4
Bit Name INTM1 INTM0
Initial Value All 0 0 0
R/W R R/W R/W
Description Reserved These are read-only bits and cannot be modified. Interrupt Control Select Mode 1 and 0 These bits select either of two interrupt control modes for the interrupt controller. 00: Interrupt control mode 0 Interrupts are controlled by I bit in CCR. 01: Setting prohibited. 10: Interrupt control mode 2 Interrupts are controlled by bits I2 to I0 in EXR, and IPR. 11: Setting prohibited.
3
NMIEG
0
R/W
NMI Edge Select Selects the input edge for the NMI pin. 0: Interrupt request generated at falling edge of NMI input 1: Interrupt request generated at rising edge of NMI input
2 to 0
All 0
R
Reserved These are read-only bits and cannot be modified.
Rev.2.00 Jun. 28, 2007 Page 88 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
5.3.2
CPU Priority Control Register (CPUPCR)
CPUPCR sets whether or not the CPU has priority over the DTC. The interrupt exception handling by the CPU can be given priority over that of the DTC transfer. The priority level of the DTC is set by bits DTCP2 to DTCP0 in CPUPCR.
Bit Bit Name Initial Value R/W 7 CPUPCE 0 R/W 6 DTCP2 0 R/W 5 DTCP1 0 R/W 4 DTCP0 0 R/W 3 IPSETE 0 R/W 2 CPUP2 0 R/(W)* 1 CPUP1 0 R/(W)* 0 CPUP0 0 R/(W)*
Note: * When the IPSETE bit is set to 1, the CPU priority is automatically updated, so these bits cannot be modified.
Bit 7
Bit Name CPUPCE
Initial Value 0
R/W R/W
Description CPU Priority Control Enable Controls the CPU priority control function. Setting this bit to 1 enables the CPU priority control. 0: CPU always has the lowest priority 1: CPU priority control enabled
6 5 4
DTCP2 DTCP1 DTCP0
0 0 0
R/W R/W R/W
DTC Priority Level 2 to 0 These bits set the DTC priority level. 000: Priority level 0 (lowest) 001: Priority level 1 010: Priority level 2 011: Priority level 3 100: Priority level 4 101: Priority level 5 110: Priority level 6 111: Priority level 7 (highest)
3
IPSETE
0
R/W
Interrupt Priority Set Enable Controls the function which automatically assigns the interrupt priority level of the CPU. Setting this bit to 1 automatically sets bits CPUP2 to CPUP0 by the CPU interrupt mask bit (I bit in CCR or bits I2 to I0 in EXR). 0: Bits CPUP2 to CPUP0 are not updated automatically 1: The interrupt mask bit value is reflected in bits CPUP2 to CPUP0
Rev.2.00 Jun. 28, 2007 Page 89 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
Bit 2 1 0
Bit Name CPUP2 CPUP1 CPUP0
Initial Value 0 0 0
R/W R/(W)* R/(W)* R/(W)*
Description CPU Priority Level 2 to 0 These bits set the CPU priority level. When the CPUPCE is set to 1, the CPU priority control function becomes valid and the priority of CPU processing is assigned in accordance with the settings of bits CPUP2 to CPUP0. 000: Priority level 0 (lowest) 001: Priority level 1 010: Priority level 2 011: Priority level 3 100: Priority level 4 101: Priority level 5 110: Priority level 6 111: Priority level 7 (highest)
Note:
*
When the IPSETE bit is set to 1, the CPU priority is automatically updated, so these bits cannot be modified.
5.3.3
Interrupt Priority Registers A to C, E to H, K, and L (IPRA to IPRC, IPRE to IPRH, IPRK, and IPRL)
IPR sets priory (levels 7 to 0) for interrupts other than NMI. Setting a value in the range from B'000 to B'111 in the 3-bit groups of bits 14 to 12, 10 to 8, 6 to 4, and 2 to 0 assigns a priority level to the corresponding interrupt. For the correspondence between the interrupt sources and the IPR settings, see table 5.2.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 0 R 7 0 R 14 IPR14 1 R/W 6 IPR6 1 R/W 13 IPR13 1 R/W 5 IPR5 1 R/W 12 IPR12 1 R/W 4 IPR4 1 R/W 11 0 R 3 0 R 10 IPR10 1 R/W 2 IPR2 1 R/W 9 IPR9 1 R/W 1 IPR1 1 R/W 8 IPR8 1 R/W 0 IPR0 1 R/W
Rev.2.00 Jun. 28, 2007 Page 90 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
Bit 15 14 13 12
Bit Name IPR14 IPR13 IPR12
Initial Value 0 1 1 1
R/W R R/W R/W R/W
Description Reserved This is a read-only bit and cannot be modified. Sets the priority level of the corresponding interrupt source. 000: Priority level 0 (lowest) 001: Priority level 1 010: Priority level 2 011: Priority level 3 100: Priority level 4 101: Priority level 5 110: Priority level 6 111: Priority level 7 (highest)
11 10 9 8
IPR10 IPR9 IPR8
0 1 1 1
R R/W R/W R/W
Reserved This is a read-only bit and cannot be modified. Sets the priority level of the corresponding interrupt source. 000: Priority level 0 (lowest) 001: Priority level 1 010: Priority level 2 011: Priority level 3 100: Priority level 4 101: Priority level 5 110: Priority level 6 111: Priority level 7 (highest)
7
0
R
Reserved This is a read-only bit and cannot be modified.
Rev.2.00 Jun. 28, 2007 Page 91 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
Bit 6 5 4
Bit Name IPR6 IPR5 IPR4
Initial Value 1 1 1
R/W R/W R/W R/W
Description Sets the priority level of the corresponding interrupt source. 000: Priority level 0 (lowest) 001: Priority level 1 010: Priority level 2 011: Priority level 3 100: Priority level 4 101: Priority level 5 110: Priority level 6 111: Priority level 7 (highest) Reserved This is a read-only bit and cannot be modified. Sets the priority level of the corresponding interrupt source. 000: Priority level 0 (lowest) 001: Priority level 1 010: Priority level 2 011: Priority level 3 100: Priority level 4 101: Priority level 5 110: Priority level 6 111: Priority level 7 (highest)
3 2 1 0
IPR2 IPR1 IPR0
0 1 1 1
R R/W R/W R/W
5.3.4
IRQ Enable Register (IER)
IER enables or disables interrupt requests IRQ11 to IRQ0.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 0 R/W 7 IRQ7E 0 R/W 14 0 R/W 6 IRQ6E 0 R/W 13 0 R/W 5 IRQ5E 0 R/W 12 0 R/W 4 IRQ4E 0 R/W 11 IRQ11E 0 R/W 3 IRQ3E 0 R/W 10 IRQ10E 0 R/W 2 IRQ2E 0 R/W 9 IRQ9E 0 R/W 1 IRQ1E 0 R/W 8 IRQ8E 0 R/W 0 IRQ0E 0 R/W
Rev.2.00 Jun. 28, 2007 Page 92 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
Bit 15 to 12
Bit Name
Initial Value All 0
R/W R/W
Description Reserved These bits are always read as 0. The write value should always be 0.
11
IRQ11E
0
R/W
IRQ11 Enable The IRQ11 interrupt request is enabled when this bit is 1.
10
IRQ10E
0
R/W
IRQ10 Enable The IRQ10 interrupt request is enabled when this bit is 1.
9 8 7 6 5 4 3 2 1 0
IRQ9E IRQ8E IRQ7E IRQ6E IRQ5E IRQ4E IRQ3E IRQ2E IRQ1E IRQ0E
0 0 0 0 0 0 0 0 0 0
R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W
IRQ9 Enable The IRQ9 interrupt request is enabled when this bit is 1. IRQ8 Enable The IRQ8 interrupt request is enabled when this bit is 1. IRQ7 Enable The IRQ7 interrupt request is enabled when this bit is 1. IRQ6 Enable The IRQ6 interrupt request is enabled when this bit is 1. IRQ5 Enable The IRQ5 interrupt request is enabled when this bit is 1. IRQ4 Enable The IRQ4 interrupt request is enabled when this bit is 1. IRQ3 Enable The IRQ3 interrupt request is enabled when this bit is 1. IRQ2 Enable The IRQ2 interrupt request is enabled when this bit is 1. IRQ1 Enable The IRQ1 interrupt request is enabled when this bit is 1. IRQ0 Enable The IRQ0 interrupt request is enabled when this bit is 1.
Rev.2.00 Jun. 28, 2007 Page 93 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
5.3.5
IRQ Sense Control Registers H and L (ISCRH, ISCRL)
ISCRH and ISCRL select the source that generates an interrupt request on pins IRQ11 to IRQ0. Upon changing the setting of ISCR, IRQnF (n = 0 to 11) in ISR is often set to 1 accidentally through an internal operation. In this case, an interrupt exception handling is executed if an IRQn interrupt request is enabled. In order to prevent such an accidental interrupt from occurring, the setting of ISCR should be changed while the IRQn interrupt is disabled, and then the IRQnF in ISR should be cleared to 0. * ISCRH
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 0 R/W 7 IRQ11SR 0 R/W 14 0 R/W 6 IRQ11SF 0 R/W 13 0 R/W 5 IRQ10SR 0 R/W 12 0 R/W 4 IRQ10SF 0 R/W 11 0 R/W 3 IRQ9SR 0 R/W 10 0 R/W 2 IRQ9SF 0 R/W 9 0 R/W 1 IRQ8SR 0 R/W 8 0 R/W 0 IRQ8SF 0 R/W
* ISCRL
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 IRQ7SR 0 R/W 7 IRQ3SR 0 R/W 14 IRQ7SF 0 R/W 6 IRQ3SF 0 R/W 13 IRQ6SR 0 R/W 5 IRQ2SR 0 R/W 12 IRQ6SF 0 R/W 4 IRQ2SF 0 R/W 11 IRQ5SR 0 R/W 3 IRQ1SR 0 R/W 10 IRQ5SF 0 R/W 2 IRQ1SF 0 R/W 9 IRQ4SR 0 R/W 1 IRQ0SR 0 R/W 8 IRQ4SF 0 R/W 0 IRQ0SF 0 R/W
Rev.2.00 Jun. 28, 2007 Page 94 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
* ISCRH
Bit Bit Name Initial Value All 0 R/W R/W Description Reserved These bits are always read as 0. The write value should always be 0. 7 6 IRQ11SR IRQ11SF 0 0 R/W R/W IRQ11 Sense Control Rise IRQ11 Sense Control Fall 00: Interrupt request generated by low level of IRQ11 01: Interrupt request generated at falling edge of IRQ11 10: Interrupt request generated at rising edge of IRQ11 11: Interrupt request generated at both falling and rising edges of IRQ11 5 4 IRQ10SR IRQ10SF 0 0 R/W R/W IRQ10 Sense Control Rise IRQ10 Sense Control Fall 00: Interrupt request generated by low level of IRQ10 01: Interrupt request generated at falling edge of IRQ10 10: Interrupt request generated at rising edge of IRQ10 11: Interrupt request generated at both falling and rising edges of IRQ10 3 2 IRQ9SR IRQ9SF 0 0 R/W R/W IRQ9 Sense Control Rise IRQ9 Sense Control Fall 00: Interrupt request generated by low level of IRQ9 01: Interrupt request generated at falling edge of IRQ9 10: Interrupt request generated at rising edge of IRQ9 11: Interrupt request generated at both falling and rising edges of IRQ9 1 0 IRQ8SR IRQ8SF 0 0 R/W R/W IRQ8 Sense Control Rise IRQ8 Sense Control Fall 00: Interrupt request generated by low level of IRQ8 01: Interrupt request generated at falling edge of IRQ8 10: Interrupt request generated at rising edge of IRQ8 11: Interrupt request generated at both falling and rising edges of IRQ8
15 to 8
Rev.2.00 Jun. 28, 2007 Page 95 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
* ISCRL
Bit 15 14 Bit Name IRQ7SR IRQ7SF Initial Value 0 0 R/W R/W R/W Description IRQ7 Sense Control Rise IRQ7 Sense Control Fall 00: Interrupt request generated by low level of IRQ7 01: Interrupt request generated at falling edge of IRQ7 10: Interrupt request generated at rising edge of IRQ7 11: Interrupt request generated at both falling and rising edges of IRQ7 13 12 IRQ6SR IRQ6SF 0 0 R/W R/W IRQ6 Sense Control Rise IRQ6 Sense Control Fall 00: Interrupt request generated by low level of IRQ6 01: Interrupt request generated at falling edge of IRQ6 10: Interrupt request generated at rising edge of IRQ6 11: Interrupt request generated at both falling and rising edges of IRQ6 11 10 IRQ5SR IRQ5SF 0 0 R/W R/W IRQ5 Sense Control Rise IRQ5 Sense Control Fall 00: Interrupt request generated by low level of IRQ5 01: Interrupt request generated at falling edge of IRQ5 10: Interrupt request generated at rising edge of IRQ5 11: Interrupt request generated at both falling and rising edges of IRQ5 9 8 IRQ4SR IRQ4SF 0 0 R/W R/W IRQ4 Sense Control Rise IRQ4 Sense Control Fall 00: Interrupt request generated by low level of IRQ4 01: Interrupt request generated at falling edge of IRQ4 10: Interrupt request generated at rising edge of IRQ4 11: Interrupt request generated at both falling and rising edges of IRQ4
Rev.2.00 Jun. 28, 2007 Page 96 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
Bit 7 6
Bit Name IRQ3SR IRQ3SF
Initial Value 0 0
R/W R/W R/W
Description IRQ3 Sense Control Rise IRQ3 Sense Control Fall 00: Interrupt request generated by low level of IRQ3 01: Interrupt request generated at falling edge of IRQ3 10: Interrupt request generated at rising edge of IRQ3 11: Interrupt request generated at both falling and rising edges of IRQ3
5 4
IRQ2SR IRQ2SF
0 0
R/W R/W
IRQ2 Sense Control Rise IRQ2 Sense Control Fall 00: Interrupt request generated by low level of IRQ2 01: Interrupt request generated at falling edge of IRQ2 10: Interrupt request generated at rising edge of IRQ2 11: Interrupt request generated at both falling and rising edges of IRQ2
3 2
IRQ1SR IRQ1SF
0 0
R/W R/W
IRQ1 Sense Control Rise IRQ1 Sense Control Fall 00: Interrupt request generated by low level of IRQ1 01: Interrupt request generated at falling edge of IRQ1 10: Interrupt request generated at rising edge of IRQ1 11: Interrupt request generated at both falling and rising edges of IRQ1
1 0
IRQ0SR IRQ0SF
0 0
R/W R/W
IRQ0 Sense Control Rise IRQ0 Sense Control Fall 00: Interrupt request generated by low level of IRQ0 01: Interrupt request generated at falling edge of IRQ0 10: Interrupt request generated at rising edge of IRQ0 11: Interrupt request generated at both falling and rising edges of IRQ0
Rev.2.00 Jun. 28, 2007 Page 97 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
5.3.6
IRQ Status Register (ISR)
ISR is an IRQ11 to IRQ0 interrupt request register.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W Note: * 15 0 R/W 7 IRQ7F 0 R/(W)* 14 0 R/W 6 IRQ6F 0 R/(W)* 13 0 R/W 5 IRQ5F 0 R/(W)* 12 0 R/W 4 IRQ4F 0 R/(W)* 11 IRQ11F 0 R/(W)* 3 IRQ3F 0 R/(W)* 10 IRQ10F 0 R/(W)* 2 IRQ2F 0 R/(W)* 9 IRQ9F 0 R/(W)* 1 IRQ1F 0 R/(W)* 8 IRQ8F 0 R/(W)* 0 IRQ0F 0 R/(W)*
Only 0 can be written, to clear the flag. The bit manipulation instructions or memory operation instructions should be used to clear the flag.
Bit 15 to 12
Bit Name
Initial Value All 0
R/W R/W
Description Reserved These bits are always read as 0. The write value should always be 0.
11 10 9 8 7 6 5 4 3 2 1 0 Note: *
IRQ11F IRQ10F IRQ9F IRQ8F IRQ7F IRQ6F IRQ5F IRQ4F IRQ3F IRQ2F IRQ1F IRQ0F
0 0 0 0 0 0 0 0 0 0 0 0
R/(W)* [Setting condition] R/(W)* * R/(W)* * R/(W)* * R/(W)* R/(W)* * R/(W)* R/(W)* R/(W)* R/(W)* R/(W)* * When the interrupt selected by ISCR occurs Writing 0 after reading IRQnF = 1 When interrupt exception handling is executed when low-level sensing is selected and IRQn input is high When IRQn interrupt exception handling is executed when falling-, rising-, or both-edge sensing is selected When the DTC is activated by an IRQn interrupt, and the DISEL bit in MRB of the DTC is cleared to 0 R/(W)* [Clearing conditions]
Only 0 can be written, to clear the flag.
Rev.2.00 Jun. 28, 2007 Page 98 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
5.3.7
Software Standby Release IRQ Enable Register (SSIER)
SSIER selects pins used to leave software standby mode from pins IRQ11 to IRQ0. The IRQ interrupt used to leave software standby mode should not be set as the DTC activation source.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 0 R/W 7 SSI7 0 R/W 14 0 R/W 6 SSI6 0 R/W 13 0 R/W 5 SSI5 0 R/W 12 0 R/W 4 SSI4 0 R/W 11 SSI11 0 R/W 3 SSI3 0 R/W 10 SSI10 0 R/W 2 SSI2 0 R/W 9 SSI9 0 R/W 1 SSI1 0 R/W 8 SSI8 0 R/W 0 SSI0 0 R/W
Bit 15 to 12
Bit Name
Initial Value All 0
R/W R/W
Description Reserved These bits are always read as 0. The write value should always be 0.
11 10 9 8 7 6 5 4 3 2 1 0
SSI11 SSI10 SSI9 SSI8 SSI7 SSI6 SSI5 SSI4 SSI3 SSI2 SSI1 SSI0
0 0 0 0 0 0 0 0 0 0 0 0
R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W
Software Standby Release IRQ Setting These bits select the IRQn pins used to leave software standby mode (n = 11 to 0). 0: IRQn requests are not sampled in software standby mode 1: When an IRQn request occurs in software standby mode, this LSI leaves software standby mode after the oscillation settling time has elapsed
Rev.2.00 Jun. 28, 2007 Page 99 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
5.4
5.4.1
Interrupt Sources
External Interrupts
There are thirteen external interrupts: NMI and IRQ11 to IRQ0. These interrupts can be used to leave software standby mode. (1) NMI Interrupts
Nonmaskable interrupt request (NMI) is the highest-priority interrupt, and is always accepted by the CPU regardless of the interrupt control mode or the settings of the CPU interrupt mask bits. The NMIEG bit in INTCR selects whether an interrupt is requested at the rising or falling edge on the NMI pin. When an NMI interrupt is generated, the interrupt controller determines that an error has occurred, and performs the following procedure. * Sets the ERR bit in DTCCR to 1. (2) IRQn Interrupts:
An IRQn interrupt is requested by a signal input on pins IRQ11 to IRQ0. IRQn (n = 11 to 0) have the following features: * Using ISCR, it is possible to select whether an interrupt is generated by a low level, falling edge, rising edge, or both edges, on pins IRQn. * Enabling or disabling of interrupt requests IRQn can be selected by IER. * The interrupt priority can be set by IPR. * The status of interrupt requests IRQn is indicated in ISR. ISR flags can be cleared to 0 by software. The bit manipulation instructions and memory operation instructions should be used to clear the flag. Detection of IRQn interrupts is enabled through the P1ICR, P2ICR, and P5ICR register settings, and does not change regardless of the output setting. However, when a pin is used as an external interrupt input pin, the pin must not be used as an I/O pin for another function by clearing the corresponding DDR bit to 0.
Rev.2.00 Jun. 28, 2007 Page 100 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
A block diagram of interrupts IRQn is shown in figure 5.2.
IRQnE
Corresponding bit in ICR
IRQnSF, IRQnSR IRQnF
Input buffer IRQn input
Edge/level detection circuit
IRQn interrupt request S R Q
[Legend] n = 14 to 0
Clear signal
Figure 5.2 Block Diagram of Interrupts IRQn When the IRQ sensing control in ISCR is set to a low level of signal IRQn, the level of IRQn should be held low until an interrupt handling starts. Then set the corresponding input signal IRQn to high in the interrupt handling routine and clear the IRQnF to 0. Interrupts may not be executed when the corresponding input signal IRQn is set to high before the interrupt handling begins. 5.4.2 Internal Interrupts
The sources for internal interrupts from on-chip peripheral modules have the following features: * For each on-chip peripheral module there are flags that indicate the interrupt request status, and enable bits that enable or disable these interrupts. They can be controlled independently. When the enable bit is set to 1, an interrupt request is issued to the interrupt controller. * The interrupt priority can be set by means of IPR. * The DTC can be activated by a TPU, SCI, or other interrupt request. * DTC activation can be controlled by the CPU priority control enable and DTC priority bits.
Rev.2.00 Jun. 28, 2007 Page 101 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
5.5
Interrupt Exception Handling Vector Table
Table 5.2 lists interrupt exception handling sources, vector address offsets, and interrupt priority. In the default priority order, a lower vector number corresponds to a higher priority. When interrupt control mode 2 is set, priority levels can be changed by setting the IPR contents. The priority for interrupt sources allocated to the same level in IPR follows the default priority, that is, they are fixed. Table 5.2 Interrupt Sources, Vector Address Offsets, and Interrupt Priority
Vector Number 7 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 WDT WOVI 81 Vector Address Offset* H'001C H'0100 H'0104 H'0108 H'010C H'0110 H'0114 H'0118 H'011C H'0120 H'0124 H'0128 H'012C H'0130 H'0134 H'0138 H'013C H'0140 H'0144 IPRE10 to IPRE8 Low DTC Priority Activation High O O O O O O O O O O O O
Classification Interrupt Source External pin NMI IRQ0 IRQ1 IRQ2 IRQ3 IRQ4 IRQ5 IRQ6 IRQ7 IRQ8 IRQ9 IRQ10 IRQ11 Reserved for system use
IPR IPRA14 to IPRA12 IPRA10 to IPRA8 IPRA6 to IPRA4 IPRA2 to IPRA0 IPRB14 to IPRB12 IPRB10 to IPRB8 IPRB6 to IPRB4 IPRB2 to IPRB0 IPRC14 to IPRC12 IPRC10 to IPRC8 IPRC6 to IPRC4 IPRC2 to IPRC0
Rev.2.00 Jun. 28, 2007 Page 102 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
Classification Interrupt Source Reserved for system use
Vector Number 82 83 84 85
Vector Address Offset* H'0148 H'014C H'015C H'0154 H'0158 H'015C H'0160 H'0164 H'0168 H'016C H'0170 H'0174 H'0178 H'017C H'0180 H'0184 H'0188 H'018C H'0190 H'0194 H'0198 H'019C H'01A0 H'01A4 H'01A8 H'01AC H'01B0 H'01B4 H'01B8 H'01BC H'01C0 H'01C4
IPR
DTC Priority Activation High
A/D TPU_0
ADI Reserved for system use TGI0A TGI0B TGI0C TGI0D TCI0V
86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113
IPRF10 to IPRF8 IPRF6 to IPRF4
O O O O O
TPU_1
TGI1A TGI1B TCI1V TCI1U
IPRF2 to IPRF0
O O
TPU_2
TGI2A TGI2B TCI2V TCI2U
IPRG14 to IPRG12
O O
TPU_3
TGI3A TGI3B TGI3C TGI3D TCI3V
IPRG10 to IPRG8
O O O O
TPU_4
TGI4A TGI4B TCI4V TCI4U
IPRG6 to IPRG4
O O
TPU_5
TGI5A TGI5B TCI5V TCI5U
IPRG2 to IPRG0
O O Low
Rev.2.00 Jun. 28, 2007 Page 103 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
Classification Interrupt Source Reserved for system use
Vector Number 114 115
Vector Address Offset* H'01C8 H'01CC H'01D0 H'01D4 H'01D8 H'01DC H'01E0 H'01E4 H'01E8 H'01EC H'01F0 H'01F4 H'01F8 H'01FC H'0200 H'0204 H'0208 H'020C H'0210 H'0214 H'0218 H'021C H'0220 H'0224 H'0228 H'022C H'0230 H'0234 H'0238 H'023C
IPR
DTC Priority Activation High
TMR_0
CMI0A CMI0B OV0I
116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143
IPRH14 to IPRH12
O O
TMR_1
CMI1A CMI1B OV1I
IPRH10 to IPRH8
O O
TMR_2
CMI2A CMI2B OV2I
IPRH6 to IPRH4
O O
TMR_3
CMI3A CMI3B OV3I
IPRH2 to IPRH0
O O
Reserved for system use

Low
Rev.2.00 Jun. 28, 2007 Page 104 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
Classification Interrupt Source SCI_0 ERI0 RXI0 TXI0 TEI0 SCI_1 ERI1 RXI1 TXI1 TEI1 SCI_2 ERI2 RXI2 TXI2 TEI2
Vector Number 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159
Vector Address Offset* H'0240 H'0244 H'0248 H'024C H'0250 H'0254 H'0258 H'025C H'0260 H'0264 H'0268 H'026C H'0270 H'0274 H'0278 H'027C H'0280 H'0284 H'0288 H'028C H'0290 | H'03FC
IPR IPRK6 to IPRK4
DTC Priority Activation High O O O O O O
IPRK2 to IPRK0
IPRL14 to IPRL12
Reserved for system use

IPRL6 to IPRL4 O O | Low
SCI_4
ERI4 RXI4 TXI4 TEI4
160 161 162 163 164 | 255
Reserved for system use
Note:
*
Lower 16 bits of the start address in advanced, middle, and maximum modes.
Rev.2.00 Jun. 28, 2007 Page 105 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
5.6
Interrupt Control Modes and Interrupt Operation
The interrupt controller has two interrupt control modes: interrupt control mode 0 and interrupt control mode 2. Interrupt operations differ depending on the interrupt control mode. The interrupt control mode is selected by INTCR. Table 5.3 shows the differences between interrupt control mode 0 and interrupt control mode 2. Table 5.3 Interrupt Control Modes
Interrupt Mask Bit I
Interrupt Priority Setting Control Mode Register 0 Default
Description The priority levels of the interrupt sources are fixed default settings. The interrupts except for NMI is masked by the I bit. Eight priority levels can be set for interrupt sources except for NMI with IPR. 8-level interrupt mask control is performed by bits I2 to I0.
2
IPR
I2 to I0
5.6.1
Interrupt Control Mode 0
In interrupt control mode 0, interrupt requests except for NMI are masked by the I bit in CCR of the CPU. Figure 5.3 shows a flowchart of the interrupt acceptance operation in this case. 1. If an interrupt request occurs when the corresponding interrupt enable bit is set to 1, the interrupt request is sent to the interrupt controller. 2. If the I bit in CCR is set to 1, only an NMI interrupt is accepted, and other interrupt requests are held pending. If the I bit is cleared to 0, an interrupt request is accepted. 3. For multiple interrupt requests, the interrupt controller selects the interrupt request with the highest priority, sends the request to the CPU, and holds other interrupt requests pending. 4. When the CPU accepts the interrupt request, it starts interrupt exception handling after execution of the current instruction has been completed. 5. The PC and CCR contents are saved to the stack area during the interrupt exception handling. The PC contents saved on the stack are the address of the first instruction to be executed after returning from the interrupt handling routine. 6. Next, the I bit in CCR is set to 1. This masks all interrupts except NMI.
Rev.2.00 Jun. 28, 2007 Page 106 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
7. The CPU generates a vector address for the accepted interrupt and starts execution of the interrupt handling routine at the address indicated by the contents of the vector address in the vector table.
Program execution state
Interrupt generated? Yes Yes
No
NMI No I=0 Yes No Pending
No IRQ0 Yes No IRQ1 Yes SSTXI2 Yes
Save PC and CCR
I1
Read vector address
Branch to interrupt handling routine
Figure 5.3 Flowchart of Procedure Up to Interrupt Acceptance in Interrupt Control Mode 0
Rev.2.00 Jun. 28, 2007 Page 107 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
5.6.2
Interrupt Control Mode 2
In interrupt control mode 2, interrupt requests except for NMI are masked by comparing the interrupt mask level (I2 to I0 bits) in EXR of the CPU and the IPR setting. There are eight levels in mask control. Figure 5.4 shows a flowchart of the interrupt acceptance operation in this case. 1. If an interrupt request occurs when the corresponding interrupt enable bit is set to 1, an interrupt request is sent to the interrupt controller. 2. For multiple interrupt requests, the interrupt controller selects the interrupt request with the highest priority according to the IPR setting, and holds other interrupt requests pending. If multiple interrupt requests have the same priority, an interrupt request is selected according to the default setting shown in table 5.2. 3. Next, the priority of the selected interrupt request is compared with the interrupt mask level set in EXR. When the interrupt request does not have priority over the mask level set, it is held pending, and only an interrupt request with a priority over the interrupt mask level is accepted. 4. When the CPU accepts an interrupt request, it starts interrupt exception handling after execution of the current instruction has been completed. 5. The PC, CCR, and EXR contents are saved to the stack area during interrupt exception handling. The PC saved on the stack is the address of the first instruction to be executed after returning from the interrupt handling routine. 6. The T bit in EXR is cleared to 0. The interrupt mask level is rewritten with the priority of the accepted interrupt. If the accepted interrupt is NMI, the interrupt mask level is set to H'7. 7. The CPU generates a vector address for the accepted interrupt and starts execution of the interrupt handling routine at the address indicated by the contents of the vector address in the vector table.
Rev.2.00 Jun. 28, 2007 Page 108 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
Program execution state
Interrupt generated?
No
Yes Yes NMI No No
Level 7 interrupt? Yes Mask level 6 or below? Yes
Level 6 interrupt? No Yes
No
Level 1 interrupt? Mask level 5 or below? Yes Mask level 0? Yes No Yes
No
No
Save PC, CCR, and EXR
Pending
Clear T bit to 0
Update mask level
Read vector address
Branch to interrupt handling routine
Figure 5.4 Flowchart of Procedure Up to Interrupt Acceptance in Interrupt Control Mode 2
Rev.2.00 Jun. 28, 2007 Page 109 of 666 REJ09B0311-0200
5.6.3
REJ09B0311-0200
Interrupt acceptance Instruction prefetch Stack Vector fetch Internal operation Internal operation Instruction prefetch in interrupt handling routine (1) (3) (5) (7) (9) (11)
Section 5 Interrupt Controller
Interrupt level determination Wait for end of instruction
I
Rev.2.00 Jun. 28, 2007 Page 110 of 666
Interrupt request signal
Internal address bus
Interrupt Exception Handling Sequence
Internal read signal
Internal write signal (2) (4) (6) (8) (10) (12)
Figure 5.5 shows the interrupt exception handling sequence. The example is for the case where interrupt control mode 0 is set in maximum mode, and the program area and stack area are in onchip memory.
Figure 5.5 Interrupt Exception Handling
(6) (8) (9) (10) (11) (12) Saved PC and saved CCR Vector address Start address of interrupt handling routine (vector address contents) Start address of interrupt handling routine ((11) = (10)) First instruction of interrupt handling routine
Internal data bus
(1)
(2) (4) (3) (5) (7)
Instruction prefetch address (Not executed. This is the contents of the saved PC, the return address.) Instruction code (Not executed.) Instruction prefetch address (Not executed.) SP - 2 SP - 4
Section 5 Interrupt Controller
5.6.4
Interrupt Response Times
Table 5.4 shows interrupt response times - the interval between generation of an interrupt request and execution of the first instruction in the interrupt handling routine. The symbols for execution states used in table 5.4 are explained in table 5.5. The stack area in on-chip RAM enables high-speed processing. Table 5.4 Interrupt Response Times
Normal Mode* Interrupt Control Mode 0
1 5
Advanced Mode Interrupt Control Mode 0 3 1 to 19 + 2*SI Interrupt Control Mode 2
Maximum Mode* Interrupt Control Mode 0
5
Execution State Interrupt priority determination*
Interrupt Control Mode 2
Interrupt Control Mode 2
Number of states until executing 2 instruction ends* PC, CCR, EXR stacking Vector fetch Instruction fetch*
3
SK to 2*SK*
6
2*SK
SK to 2*SK*
6
2*SK
2*SK
2*SK
Sh 2*SI
4
Internal processing*
2 10 to 31 11 to 31 10 to 31 11 to 31 11 to 31 11 to 31
Total (using on-chip memory)
Notes: 1. 2. 3. 4. 5. 6.
Two states for an internal interrupt. In the case of the MULXS or DIVXS instruction Prefetch after interrupt acceptance or for an instruction in the interrupt handling routine. Internal operation after interrupt acceptance or after vector fetch Not available in this LSI. When setting the SP value to 4n, the interrupt response time is SK; when setting to 4n + 2, the interrupt response time is 2*SK.
Rev.2.00 Jun. 28, 2007 Page 111 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
Table 5.5
Number of Execution States in Interrupt Handling Routine
Object of Access External Device 8-Bit Bus 16-Bit Bus 2-State Access 4 2 4 3-State Access 6 + 2m 3+m 6 + 2m
Symbol Vector fetch Sh Instruction fetch SI Stack manipulation SK
On-Chip Memory 1 1 1
2-State Access 8 4 8
3-State Access 12 + 4m 6 + 2m 12 + 4m
[Legend] m: Number of wait cycles in an external device access.
5.6.5
DTC Activation by Interrupt
The DTC can be activated by an interrupt. In this case, the following options are available: * Interrupt request to the CPU * Activation request to the DTC * Combination of the above For details on interrupt requests that can be used to activate the DTC, see table 5.2 and section 7, Data Transfer Controller (DTC).
Rev.2.00 Jun. 28, 2007 Page 112 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
Figure 5.6 shows a block diagram of the DTC and interrupt controller.
Clear signal DTCER Select signal Interrupt request On-chip peripheral Interrupt request clear signal module DTC/CPU select circuit DTC control circuit DTC activation request vector number Clear signal DTC
Interrupt request IRQ interrupt Interrupt request clear signal Interrupt controller
CPU interrupt request vector number Priority determination I, I2 to I0 CPU
Figure 5.6 Block Diagram of DTC and Interrupt Controller (1) Selection of Interrupt Sources
Each interrupt source is set for a DTC activation request or a CPU interrupt request by the DTCE bit in DTCERA to DTCERH of the DTC. Specifying the DISEL bit in MRB of the DTC generates an interrupt request to the CPU by clearing the DTCE bit to 0 after the individual DTC data transfer. Note that when the DTC performs a predetermined number of data transfers and the transfer counter indicates 0, an interrupt request is also made to the CPU by clearing the DTCE bit to 0 after the DTC data transfer. When the same interrupt source is set as both the DTC activation source and CPU interrupt source, the DTC must be given priority over the CPU. If the IPSETE is set to 1, the priority is determined according to the IPR setting. Therefore, the CPUP setting or the IPR setting corresponding to the interrupt source must be set to lower than or equal to the DTCP setting. If the CPU is given priority over the DTC, the DTC may not be activated, and the data transfer may not be performed. (2) Priority Determination
The DTC activation source is selected according to the default priority, and the selection is not affected by its mask level or priority level. For respective priority levels, see table 7.1, Interrupt Sources, DTC Vector Addresses, and Corresponding DTCEs.
Rev.2.00 Jun. 28, 2007 Page 113 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
(3)
Operation Order
If the same interrupt is selected as both the DTC activation source and CPU interrupt source, the CPU interrupt exception handling is performed after the DTC data transfer. If the same interrupt is selected as the DTC activation source or CPU interrupt source, respective operations are performed independently. Table 5.6 lists the selection of interrupt sources and interrupt source clear control by means of the setting of the DTCE bit in DTCERA to DTCERH of the DTC, and the DISEL bit in MRB of the DTC. Table 5.6 Interrupt Source Selection and Clear Control
DTC Setting DTCE 0 1 DISEL * 0 1 Interrupt Source Selection/Clear Control DTC X O CPU X
[Legend] : The corresponding interrupt is used. The interrupt source is cleared. (The interrupt source flag must be cleared in the CPU interrupt handling routine.) O: The corresponding interrupt is used. The interrupt source is not cleared. X: The corresponding interrupt is not available. *: Don't care.
(4)
Usage Note
The interrupt sources of the SCI and A/D converter are cleared according to the setting shown in table 5.6, when the DTC reads/writes the prescribed register. To initiate multiple channels for the DTC with the same interrupt, the same priority should be assigned.
Rev.2.00 Jun. 28, 2007 Page 114 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
5.7
CPU Priority Control Function Over DTC
The interrupt controller has a function to control the priority between the DTC and the CPU by assigning a priority levels to the DTC and CPU. Since the priority level can automatically be assigned to the CPU on an interrupt occurrence, it is possible to execute the CPU interrupt exception handling prior to the DTC transfer. The priority level of the CPU is assigned by bits CPUP2 to CPUP0 in CPUPCR. The priority level of the DTC is assigned by bits DTCP2 to DTCP0 in CPUPCR. The priority control function over the DTC is enabled by setting the CPUPCE bit in CPUPCR to 1. When the CPUPCE bit is 1, the DTC activation source is controlled according to the respective priority level. The DTC activation source is controlled according to the priority level of the CPU indicated by bits CPUP2 to CPUP0 and the priority level of the DTC indicated by bits DTCP2 to DTCP0. If the CPU has priority, the DTC activation source is held. The DTC is activated when the condition by which the activation source is held is cancelled (CPUCPCE = 1 and value of bits CPUP2 to CPUP0 is greater than that of bits DTCP2 to DTCP0). The priority level of the DTC is assigned by the DTCP2 to DTCP0 bits in CPUPCR regardless of the activation source. There are two methods for assigning the priority level to the CPU by the IPSETE bit in CPUPCR. Setting the IPSETE bit to 1 enables a function to automatically assign the value of the interrupt mask bit of the CPU to the CPU priority level. Clearing the IPSETE bit to 0 disables the function to automatically assign the priority level. Therefore, the priority level is assigned directly by software rewriting bits CPUP2 to CPUP0. Even if the IPSETE bit is 1, the priority level of the CPU is software assignable by rewriting the interrupt mask bit of the CPU (I bit in CCR or I2 to I0 bits in EXR). The priority level which is automatically assigned when the IPSETE bit is 1 differs according to the interrupt control mode. In interrupt control mode 0, the I bit in CCR of the CPU is reflected in bit CPUP2. Bits CPUP1 and CPUP0 are fixed 0. In interrupt control mode 2, the values of bits I2 to I0 in EXR of the CPU are reflected in bits CPUP2 to CPUP0.
Rev.2.00 Jun. 28, 2007 Page 115 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
Table 5.7 shows the CPU priority control. Table 5.7 CPU Priority Control
Control Status Interrupt Mask Bit I = any I=0 I=1 2 IPR setting I2 to I0 0 1 IPSETE in CPUPCR CPUP2 to CPUP0 0 1 B'111 to B'000 B'000 B'100 B'111 to B'000 I2 to I0 Enabled Disabled Updating of CPUP2 to CPUP0 Enabled Disabled
Interrupt Control Interrupt Mode Priority 0 Default
Table 5.8 shows a setting example of the priority control function over the DTC and the transfer request control state. Table 5.8 Example of Priority Control Function Setting and Control State
CPUP2 to CPUP0 DTCP2 to DTCP0 Transfer Request Control State DTC
Interrupt Control CPUPCE in Mode CPUPCR
0
0 1
Any B'000 B'100 B'100 B'100 B'000
Any B'000 B'000 B'000 B'111 B'111 Any B'000 B'011 B'011 B'011 B'011 B'011 B'011 B'011 B'110
Enabled Enabled Masked Masked Enabled Enabled Enabled Enabled Enabled Enabled Masked Masked Masked Masked Masked Enabled
2
0 1
Any B'000 B'000 B'011 B'100 B'101 B'110 B'111 B'101 B'101
Rev.2.00 Jun. 28, 2007 Page 116 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
5.8
5.8.1
Usage Notes
Conflict between Interrupt Generation and Disabling
When an interrupt enable bit is cleared to 0 to mask the interrupt, the masking becomes effective after execution of the instruction. When an interrupt enable bit is cleared to 0 by an instruction such as BCLR or MOV, if an interrupt is generated during execution of the instruction, the interrupt concerned will still be enabled on completion of the instruction, and so interrupt exception handling for that interrupt will be executed on completion of the instruction. However, if there is an interrupt request with priority over that interrupt, interrupt exception handling will be executed for the interrupt with priority, and another interrupt will be ignored. The same also applies when an interrupt source flag is cleared to 0. Figure 5.7 shows an example in which the TCIEV bit in TIER of the TPU is cleared to 0. The above conflict will not occur if an enable bit or interrupt source flag is cleared to 0 while the interrupt is masked.
TIER_0 write cycle by CPU P Internal address bus Internal write signal TCIEV TCIV exception handling
TIER_0 address
TCFV TCIV interrupt signal
Figure 5.7 Conflict between Interrupt Generation and Disabling If an interrupt is generated immediately before rewriting the DTC enable bit, both DTC activation and CPU interrupt exception handling are executed. To rewrite the DTC enable bit, execute this while the corresponding interrupt request is not generated.
Rev.2.00 Jun. 28, 2007 Page 117 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
5.8.2
Instructions that Disable Interrupts
Instructions that disable interrupts immediately after execution are LDC, ANDC, ORC, and XORC. After any of these instructions is executed, all interrupts including NMI are disabled and the next instruction is always executed. When the I bit is set by one of these instructions, the new value becomes valid two states after execution of the instruction ends. 5.8.3 Times when Interrupts are Disabled
There are times when interrupt acceptance is disabled by the interrupt controller. The interrupt controller disables interrupt acceptance for a 3-state period after the CPU has updated the mask level with an LDC, ANDC, ORC, or XORC instruction, and for a period of writing to the registers of the interrupt controller. 5.8.4 Interrupts during Execution of EEPMOV Instruction
Interrupt operation differs between the EEPMOV.B and the EEPMOV.W instructions. With the EEPMOV.B instruction, an interrupt request (including NMI) issued during the transfer is not accepted until the transfer is completed. With the EEPMOV.W instruction, if an interrupt request is issued during the transfer, interrupt exception handling starts at the end of the individual transfer cycle. The PC value saved on the stack in this case is the address of the next instruction. Therefore, if an interrupt is generated during execution of an EEPMOV.W instruction, the following coding should be used.
L1: EEPMOV.W MOV.W BNE R4,R4 L1
5.8.5
Interrupts during Execution of MOVMD and MOVSD Instructions
With the MOVMD or MOVSD instruction, if an interrupt request is issued during the transfer, interrupt exception handling starts at the end of the individual transfer cycle. The PC value saved on the stack in this case is the address of the MOVMD or MOVSD instruction. The transfer of the remaining data is resumed after returning from the interrupt handling routine.
Rev.2.00 Jun. 28, 2007 Page 118 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
5.8.6
Interrupts Source Flag of Peripheral Modules
To clear an interrupt source flag by the CPU using an interrupt function of a peripheral module, the flag must be read from after clearing within the interrupt processing routine. This makes the request signal synchronized with the peripheral module clock.
Rev.2.00 Jun. 28, 2007 Page 119 of 666 REJ09B0311-0200
Section 5 Interrupt Controller
Rev.2.00 Jun. 28, 2007 Page 120 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Section 6 Bus Controller (BSC)
This LSI has an on-chip bus controller (BSC) that manages the external address space divided into eight areas. The bus controller also has a bus arbitration function, and controls the operation of the internal bus masters; CPU and DTC.
6.1
Features
* Manages external address space in area units Manages the external address space divided into eight areas. Chip select signals (CS0 to CS7) can be output for each area. Bus specifications can be set independently for each area. 8-bit access or 16-bit access can be selected for each area. Burst ROM, byte control SRAM, or address/data multiplexed I/O interface can be set. An endian conversion function is provided to connect a device of little endian. * Basic bus interface This interface can be connected to the SRAM and ROM. 2-state access or 3-state access can be selected for each area. Program wait cycles can be inserted for each area. Wait cycles can be inserted by the WAIT pin. Extension cycles can be inserted while CSn is asserted for each area (n = 0 to 7). The negation timing of the read strobe signal (RD) can be modified. * Byte control SRAM interface Byte control SRAM interface can be set for areas 0 to 7. The SRAM that has a byte control pin can be directly connected. * Burst ROM interface Burst ROM interface can be set for areas 0 and 1. Burst ROM interface parameters can be set independently for areas 0 and 1. * Address/data multiplexed I/O interface Address/data multiplexed I/O interface can be set for areas 3 to 7.
Rev.2.00 Jun. 28, 2007 Page 121 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
* Idle cycle insertion Idle cycles can be inserted between external read accesses to different areas. Idle cycles can be inserted before the external write access after an external read access. Idle cycles can be inserted before the external read access after an external write access. * Write buffer function External write cycles and internal accesses can be executed in parallel Write accesses to the on-chip peripheral module and on-chip memory accesses can be executed in parallel * External bus release function * Bus arbitration function Includes a bus arbiter that arbitrates bus mastership between the CPU and DTC * Multi-clock function The internal peripheral functions can be operated in synchronization with the peripheral module clock (P). Accesses to the external address space can be operated in synchronization with the external bus clock (B). * The bus start (BS) and read/write (RD/WR) signals can be output.
Rev.2.00 Jun. 28, 2007 Page 122 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
A block diagram of the bus controller is shown in figure 6.1.
CPU address bus DTC address bus Address selecter Area decoder CS7 to CS0
Internal bus control signals CPU bus mastership acknowledge signal DTC bus mastership acknowledge signal CPU bus mastership request signal DTC bus mastership request signal
Internal bus control unit External bus control unit Internal bus arbiter External bus arbiter
External bus control signals WAIT
BREQ BACK BREQO
Control register Internal data bus ABWCR ASTCR WTCRA WTCRB RDNCR CSACR [Legend] ABWCR: ASTCR: WTCRA: WTCRB: RDNCR: CSACR: IDLCR BCR1 BCR2 ENDIANCR SRAMCR BROMCR MPXCR
Bus width control register Access state control register Wait control register A Wait control register B Read strobe timing control register CS assertion period control register
IDLCR: BCR1: BCR2: ENDIANCR: SRAMCR: BROMCR: MPXCR:
Idle control register Bus control register 1 Bus control register 2 Endian control register SRAM mode control register Burst ROM interface control register Address/data multiplexed I/O control register
Figure 6.1 Block Diagram of Bus Controller
Rev.2.00 Jun. 28, 2007 Page 123 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.2
Register Descriptions
The bus controller has the following registers. * * * * * * * * * * * * * Bus width control register (ABWCR) Access state control register (ASTCR) Wait control register A (WTCRA) Wait control register B (WTCRB) Read strobe timing control register (RDNCR) CS assertion period control register (CSACR) Idle control register (IDLCR) Bus control register 1 (BCR1) Bus control register 2 (BCR2) Endian control register (ENDIANCR) SRAM mode control register (SRAMCR) Burst ROM interface control register (BROMCR) Address/data multiplexed I/O control register (MPXCR) Bus Width Control Register (ABWCR)
6.2.1
ABWCR specifies the data bus width for each area in the external address space.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 ABWH7 1 R/W 7 ABWL7 1 R/W 14 ABWH6 1 R/W 6 ABWL6 1 R/W 13 ABWH5 1 R/W 5 ABWL5 1 R/W 12 ABWH4 1 R/W 4 ABWL4 1 R/W 11 ABWH3 1 R/W 3 ABWL3 1 R/W 10 ABWH2 1 R/W 2 ABWL2 1 R/W 9 ABWH1 1 R/W 1 ABWL1 1 R/W 8 ABWH0 1/0 R/W 0 ABWL0 1 R/W
Note: * Initial value at 16-bit bus initiation is H'FEFF, and that at 8-bit bus initiation is H'FFFF.
Rev.2.00 Jun. 28, 2007 Page 124 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Bit 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
Bit Name ABWH7 ABWH6 ABWH5 ABWH4 ABWH3 ABWH2 ABWH1 ABWL0 ABWL7 ABWL6 ABWL5 ABWL4 ABWL3 ABWL2 ABWL1 ABWL0
Initial Value*1 1 1 1 1 1 1 1 1/0 1 1 1 1 1 1 1 1
R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W
Description Area 7 to 0 Bus Width Control These bits select whether the corresponding area is to be designated as 8-bit access space or 16-bit access space. ABWHn x 0 1 ABWLn (n = 7 to 0) 0: 1: 1: Setting prohibited Area n is designated as 16-bit access space Area n is designated as 8-bit access 2 space*
[Legend] x: Don't care Notes: 1. Initial value at 16-bit bus initiation is H'FEFF, and that at 8-bit bus initiation is H'FFFF. 2. An address space specified as byte control SRAM interface must not be specified as 8bit access space.
Rev.2.00 Jun. 28, 2007 Page 125 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.2.2
Access State Control Register (ASTCR)
ASTCR designates each area in the external address space as either 2-state access space or 3-state access space and enables/disables wait cycle insertion.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 AST7 1 R/W 7 0 R 14 AST6 1 R/W 6 0 R 13 AST5 1 R/W 5 0 R 12 AST4 1 R/W 4 0 R 11 AST3 1 R/W 3 0 R 10 AST2 1 R/W 2 0 R 9 AST1 1 R/W 1 0 R 8 AST0 1 R/W 0 0 R
Bit 15 14 13 12 11 10 9 8
Bit Name AST7 AST6 AST5 AST4 AST3 AST2 AST1 AST0
Initial Value 1 1 1 1 1 1 1 1
R/W R/W R/W R/W R/W R/W R/W R/W R/W
Description Area 7 to 0 Access State Control These bits select whether the corresponding area is to be designated as 2-state access space or 3-state access space. Wait cycle insertion is enabled or disabled at the same time. 0: Area n is designated as 2-state access space Wait cycle insertion in area n access is disabled 1: Area n is designated as 3-state access space Wait cycle insertion in area n access is enabled (n = 7 to 0) Reserved These are read-only bits and cannot be modified.
7 to 0
All 0
R
Rev.2.00 Jun. 28, 2007 Page 126 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.2.3
Wait Control Registers A and B (WTCRA, WTCRB)
WTCRA and WTCRB select the number of program wait cycles for each area in the external address space.
* WTCRA Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W * WTCRB Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 0 R 7 0 R 14 W32 1 R/W 6 W12 1 R/W 13 W31 1 R/W 5 W11 1 R/W 12 W30 1 R/W 4 W10 1 R/W 11 0 R 3 0 R 10 W22 1 R/W 2 W02 1 R/W 9 W21 1 R/W 1 W01 1 R/W 8 W20 1 R/W 0 W00 1 R/W 15 0 R 7 0 R 14 W72 1 R/W 6 W52 1 R/W 13 W71 1 R/W 5 W51 1 R/W 12 W70 1 R/W 4 W50 1 R/W 11 0 R 3 0 R 10 W62 1 R/W 2 W42 1 R/W 9 W61 1 R/W 1 W41 1 R/W 8 W60 1 R/W 0 W40 1 R/W
Rev.2.00 Jun. 28, 2007 Page 127 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
* WTCRA
Bit 15 14 13 12 Bit Name W72 W71 W70 Initial Value 0 1 1 1 R/W R R/W R/W R/W Description Reserved This is a read-only bit and cannot be modified. Area 7 Wait Control 2 to 0 These bits select the number of program wait cycles when accessing area 7 while bit AST7 in ASTCR is 1. 000: Program wait cycle not inserted 001: 1 program wait cycle inserted 010: 2 program wait cycles inserted 011: 3 program wait cycles inserted 100: 4 program wait cycles inserted 101: 5 program wait cycles inserted 110: 6 program wait cycles inserted 111: 7 program wait cycles inserted 11 10 9 8 W62 W61 W60 0 1 1 1 R R/W R/W R/W Reserved This is a read-only bit and cannot be modified. Area 6 Wait Control 2 to 0 These bits select the number of program wait cycles when accessing area 6 while bit AST6 in ASTCR is 1. 000: Program wait cycle not inserted 001: 1 program wait cycle inserted 010: 2 program wait cycles inserted 011: 3 program wait cycles inserted 100: 4 program wait cycles inserted 101: 5 program wait cycles inserted 110: 6 program wait cycles inserted 111: 7 program wait cycles inserted 7 0 R Reserved This is a read-only bit and cannot be modified.
Rev.2.00 Jun. 28, 2007 Page 128 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Bit 6 5 4
Bit Name W52 W51 W50
Initial Value 1 1 1
R/W R/W R/W R/W
Description Area 5 Wait Control 2 to 0 These bits select the number of program wait cycles when accessing area 5 while bit AST5 in ASTCR is 1. 000: Program cycle wait not inserted 001: 1 program wait cycle inserted 010: 2 program wait cycles inserted 011: 3 program wait cycles inserted 100: 4 program wait cycles inserted 101: 5 program wait cycles inserted 110: 6 program wait cycles inserted 111: 7 program wait cycles inserted
3 2 1 0
W42 W41 W40
0 1 1 1
R R/W R/W R/W
Reserved This is a read-only bit and cannot be modified. Area 4 Wait Control 2 to 0 These bits select the number of program wait cycles when accessing area 4 while bit AST4 in ASTCR is 1. 000: Program wait cycle not inserted 001: 1 program wait cycle inserted 010: 2 program wait cycles inserted 011: 3 program wait cycles inserted 100: 4 program wait cycles inserted 101: 5 program wait cycles inserted 110: 6 program wait cycles inserted 111: 7 program wait cycles inserted
Rev.2.00 Jun. 28, 2007 Page 129 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
* WTCRB
Bit 15 14 13 12 Bit Name W32 W31 W30 Initial Value 0 1 1 1 R/W R R/W R/W R/W Description Reserved This is a read-only bit and cannot be modified. Area 3 Wait Control 2 to 0 These bits select the number of program wait cycles when accessing area 3 while bit AST3 in ASTCR is 1. 000: Program wait cycle not inserted 001: 1 program wait cycle inserted 010: 2 program wait cycles inserted 011: 3 program wait cycles inserted 100: 4 program wait cycles inserted 101: 5 program wait cycles inserted 110: 6 program wait cycles inserted 111: 7 program wait cycles inserted 11 10 9 8 W22 W21 W20 0 1 1 1 R R/W R/W R/W Reserved This is a read-only bit and cannot be modified. Area 2 Wait Control 2 to 0 These bits select the number of program wait cycles when accessing area 2 while bit AST2 in ASTCR is 1. 000: Program wait cycle not inserted 001: 1 program wait cycle inserted 010: 2 program wait cycles inserted 011: 3 program wait cycles inserted 100: 4 program wait cycles inserted 101: 5 program wait cycles inserted 110: 6 program wait cycles inserted 111: 7 program wait cycles inserted 7 0 R Reserved This is a read-only bit and cannot be modified.
Rev.2.00 Jun. 28, 2007 Page 130 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Bit 6 5 4
Bit Name W12 W11 W10
Initial Value 1 1 1
R/W R/W R/W R/W
Description Area 1 Wait Control 2 to 0 These bits select the number of program wait cycles when accessing area 1 while bit AST1 in ASTCR is 1. 000: Program wait cycle not inserted 001: 1 program wait cycle inserted 010: 2 program wait cycles inserted 011: 3 program wait cycles inserted 100: 4 program wait cycles inserted 101: 5 program wait cycles inserted 110: 6 program wait cycles inserted 111: 7 program wait cycles inserted
3 2 1 0
W02 W01 W00
0 1 1 1
R R/W R/W R/W
Reserved This is a read-only bit and cannot be modified. Area 0 Wait Control 2 to 0 These bits select the number of program wait cycles when accessing area 0 while bit AST0 in ASTCR is 1. 000: Program wait cycle not inserted 001: 1 program wait cycle inserted 010: 2 program wait cycles inserted 011: 3 program wait cycles inserted 100: 4 program wait cycles inserted 101: 5 program wait cycles inserted 110: 6 program wait cycles inserted 111: 7 program wait cycles inserted
Rev.2.00 Jun. 28, 2007 Page 131 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.2.4
Read Strobe Timing Control Register (RDNCR)
RDNCR selects the negation timing of the read strobe signal (RD) when reading the external address spaces specified as a basic bus interface or the address/data multiplexed I/O interface.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 RDN7 0 R/W 7 0 R 14 RDN6 0 R/W 6 0 R 13 RDN5 0 R/W 5 0 R 12 RDN4 0 R/W 4 0 R 11 RDN3 0 R/W 3 0 R 10 RDN2 0 R/W 2 0 R 9 RDN1 0 R/W 1 0 R 8 RDN0 0 R/W 0 0 R
Bit 15 14 13 12 11 10 9 8
Bit Name RDN7 RDN6 RDN5 RDN4 RDN3 RDN2 RDN1 RDN0
Initial Value 0 0 0 0 0 0 0 0
R/W R/W R/W R/W R/W R/W R/W R/W R/W
Description Read Strobe Timing Control These bits set the negation timing of the read strobe in a corresponding area read access. As shown in figure 6.2, the read strobe for an area for which the RDNn bit is set to 1 is negated one half-cycle earlier than that for an area for which the RDNn bit is cleared to 0. The read data setup and hold time are also given one half-cycle earlier. 0: In an area n read access, the RD signal is negated at the end of the read cycle 1: In an area n read access, the RD signal is negated one half-cycle before the end of the read cycle (n = 7 to 0)
7 to 0
All 0
R
Reserved These are read-only bits and cannot be modified.
Notes: 1. In an external address space which is specified as byte control SRAM interface, the RDNCR setting is ignored and the same operation when RDNn = 1 is performed. 2. In an external address space which is specified as burst ROM interface, the RDNCR setting is ignored and the same operation when RDNn = 0 is performed.
Rev.2.00 Jun. 28, 2007 Page 132 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Bus cycle T1 B
T2
T3
RD RDNn = 0 Data RD RDNn = 1 Data
(n = 7 to 0)
Figure 6.2 Read Strobe Negation Timing (Example of 3-State Access Space) 6.2.5 CS Assertion Period Control Registers (CSACR)
CSACR selects whether or not the assertion periods of the chip select signals (CSn) and address signals for the basic bus, byte-control SRAM, burst ROM, and address/data multiplexed I/O interface are to be extended. Extending the assertion period of the CSn and address signals allows the setup time and hold time of read strobe (RD) and write strobe (LHWR/LLWR) to be assured and to make the write data setup time and hold time for the write strobe become flexible.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 CSXH7 0 R/W 7 CSXT7 0 R/W 14 CSXH6 0 R/W 6 CSXT6 0 R/W 13 CSXH5 0 R/W 5 CSXT5 0 R/W 12 CSXH4 0 R/W 4 CSXT4 0 R/W 11 CSXH3 0 R/W 3 CSXT3 0 R/W 10 CSXH2 0 R/W 2 CSXT2 0 R/W 9 CSXH1 0 R/W 1 CSXT1 0 R/W 8 CSXH0 0 R/W 0 CSXT0 0 R/W
Rev.2.00 Jun. 28, 2007 Page 133 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Bit 15 14 13 12 11 10 9 8
Bit Name CSXH7 CSXH6 CSXH5 CSXH4 CSXH3 CSXH2 CSXH1 CSXH0
Initial Value 0 0 0 0 0 0 0 0
R/W R/W R/W R/W R/W R/W R/W R/W R/W
Description CS and Address Signal Assertion Period Control 1 These bits specify whether or not the Th cycle is to be inserted (see figure 6.3). When an area for which bit CSXHn is set to 1 is accessed, one Th cycle, in which the CSn and address signals are asserted, is inserted before the normal access cycle. 0: In access to area n, the CSn and address assertion period (Th) is not extended 1: In access to area n, the CSn and address assertion period (Th) is extended (n = 7 to 0) CS and Address Signal Assertion Period Control 2 These bits specify whether or not the Tt cycle is to be inserted (see figure 6.3). When an area for which bit CSXTn is set to 1 is accessed, one Tt cycle, in which the CSn and address signals are retained, is inserted after the normal access cycle. 0: In access to area n, the CSn and address assertion period (Tt) is not extended 1: In access to area n, the CSn and address assertion period (Tt) is extended (n = 7 to 0)
7 6 5 4 3 2 1 0
CSXT7 CSXT6 CSXT5 CSXT4 CSXT3 CSXT2 CSXT1 CSXT0
0 0 0 0 0 0 0 0
R/W R/W R/W R/W R/W R/W R/W R/W
Note:
*
In burst ROM interface, the CSXTn settings are ignored.
Rev.2.00 Jun. 28, 2007 Page 134 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Bus cycle Th B T1 T2 T3 Tt
Address CSn AS BS
RD/WR RD Read Data bus Read data
LHWR, LLWR Write Data bus Write data
Figure 6.3 CS and Address Assertion Period Extension (Example of Basic Bus Interface, 3-State Access Space, and RDNn = 0) 6.2.6 Idle Control Register (IDLCR)
IDLCR specifies the idle cycle insertion conditions and the number of idle cycles.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 1 R/W 7 IDLSEL7 0 R/W 14 IDLS2 1 R/W 6 IDLSEL6 0 R/W 13 IDLS1 1 R/W 5 IDLSEL5 0 R/W 12 IDLS0 1 R/W 4 IDLSEL4 0 R/W 11 IDLCB1 1 R/W 3 IDLSEL3 0 R/W 10 IDLCB0 1 R/W 2 IDLSEL2 0 R/W 9 IDLCA1 1 R/W 1 IDLSEL1 0 R/W 8 IDLCA0 1 R/W 0 IDLSEL0 0 R/W
Rev.2.00 Jun. 28, 2007 Page 135 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Bit 15
Bit Name
Initial Value 1
R/W R/W
Description Reserved This bit is always read as 1. The write value should always be 1.
14
IDLS2
1
R/W
Idle Cycle Insertion 2 Inserts an idle cycle between the bus cycles when the external write cycle is followed by external read cycle. 0: No idle cycle is inserted 1: An idle cycle is inserted
13
IDLS1
1
R/W
Idle Cycle Insertion 1 Inserts an idle cycle between the bus cycles when the external read cycles of different areas continue. 0: No idle cycle is inserted 1: An idle cycle is inserted
12
IDLS0
1
R/W
Idle Cycle Insertion 0 Inserts an idle cycle between the bus cycles when the external read cycle is followed by external write cycle. 0: No idle cycle is inserted 1: An idle cycle is inserted
11 10
IDLCB1 IDLCB0
1 1
R/W R/W
Idle Cycle State Number Select B Specifies the number of idle cycles to be inserted for the idle condition specified by IDLS1 and IDLS0. 00: No idle cycle is inserted 01: 2 idle cycles are inserted 00: 3 idle cycles are inserted 01: 4 idle cycles are inserted
9 8
IDLCA1 IDLCA0
1 1
R/W R/W
Idle Cycle State Number Select A Specifies the number of idle cycles to be inserted for the idle condition specified by IDLS2 to IDLS0. 00: 1 idle cycle is inserted 01: 2 idle cycles are inserted 10: 3 idle cycles are inserted 11: 4 idle cycles are inserted
Rev.2.00 Jun. 28, 2007 Page 136 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Bit 7 6 5 4 3 2 1 0
Bit Name IDLSEL7 IDLSEL6 IDLSEL5 IDLSEL4 IDLSEL3 IDLSEL2 IDLSEL1 IDLSEL0
Initial Value 0 0 0 0 0 0 0 0
R/W R/W R/W R/W R/W R/W R/W R/W R/W
Description Idle Cycle Number Select Specifies the number of idle cycles to be inserted for each area for the idle insertion condition specified by IDLS1 and IDLS0. 0: Number of idle cycles to be inserted for area n is specified by IDLCA1 and IDLCA0. 1: Number of idle cycles to be inserted for area n is specified by IDLCB1 and IDLCB0. (n = 7 to 0)
6.2.7
Bus Control Register 1 (BCR1)
BCR1 is used for selection of the external bus released state protocol, enabling/disabling of the write data buffer function, and enabling/disabling of the WAIT pin input.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 BRLE 0 R/W 7 0 R/W 14 BREQOE 0 R/W 6 0 R/W 13 0 R 5 0 R 12 0 R 4 0 R 11 0 R/W 3 0 R 10 0 R/W 2 0 R 9 WDBE 0 R/W 1 0 R 8 WAITE 0 R/W 0 0 R
Bit 15
Bit Name BRLE
Initial Value 0
R/W R/W
Description External Bus Release Enable Enables/disables external bus release. 0: External bus release disabled BREQ, BACK, and BREQO pins can be used as I/O ports 1: External bus release enabled* To set this bit to 1, the ICR bit of the corresponding pin should be specified to 1. For details, see section 8, I/O ports.
Rev.2.00 Jun. 28, 2007 Page 137 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Bit 14
Bit Name BREQOE
Initial Value 0
R/W R/W
Description BREQO Pin Enable Controls outputting the bus request signal (BREQO) to the external bus master in the external bus released state when an internal bus master performs an external address space access. 0: BREQO output disabled BREQO pin can be used as I/O port 1: BREQO output enabled
13, 12 11, 10

All 0 All 0
R R/W
Reserved These are read-only bits and cannot be modified. Reserved These bits are always read as 0. The write value should always be 0.
9
WDBE
0
R/W
Write Data Buffer Enable The write data buffer function can be used for an external write cycle. Note that a set value change may not be reflected to the external access immediately after the change. 0: Write data buffer function not used 1: Write data buffer function used
8
WAITE
0
R/W
WAIT Pin Enable Selects enabling/disabling of wait input by the WAIT pin. 0: Wait input by WAIT pin disabled WAIT pin can be used as I/O port 1: Wait input by WAIT pin enabled To set this bit to 1, the ICR bit of the corresponding pin should be specified to 1. For details, see section 8, I/O ports.
7, 6
All 0
R/W
Reserved These bits are always read as 0. The write value should always be 0.
5 to 0
All 0
R
Reserved These are read-only bits and cannot be modified.
Rev.2.00 Jun. 28, 2007 Page 138 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.2.8
Bus Control Register 2 (BCR2)
BCR2 is used for bus arbitration control of the CPU and DTC, and enabling/disabling of the write data buffer function to the peripheral modules.
Bit Bit Name Initial Value R/W 7 0 R 6 0 R 5 0 R/W 4 IBCCS 0 R/W 3 0 R 2 0 R 1 1 R/W 0 PWDBE 0 R/W
Bit 7, 6 5
Bit Name
Initial Value All 0 0
R/W R R/W
Description Reserved These are read-only bits and cannot be modified. Reserved This bit is always read as 0. The write value should always be 0.
4
IBCCS
0
R/W
Internal Bus Cycle Control Select Selects the internal bus arbiter function. 0: Releases the bus mastership according to the priority 1: Executes the bus cycles alternatively when a CPU bus mastership request conflicts with a DTC bus mastership request
3, 2 1

All 0 1
R R/W
Reserved These are read-only bits and cannot be modified. Reserved This bit is always read as 1. The write value should always be 1.
0
PWDBE
0
R/W
Peripheral Module Write Data Buffer Enable Specifies whether or not to use the write data buffer function for the peripheral module write cycles. 0: Write data buffer function not used 1: Write data buffer function used
Rev.2.00 Jun. 28, 2007 Page 139 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.2.9
Endian Control Register (ENDIANCR)
ENDIANCR selects the endian format for each area of the external address space. Though the data format of this LSI is big endian, data can be transferred in the little endian format during external address space access. Note that the data format for the areas used as a program area or a stack area should be big endian.
Bit Bit Name Initial Value R/W 7 LE7 0 R/W 6 LE6 0 R/W 5 LE5 0 R/W 4 LE4 0 R/W 3 LE3 0 R/W 2 LE2 0 R/W 1 0 R 0 0 R
Bit 7 6 5 4 3 2 1, 0
Bit Name LE7 LE6 LE5 LE4 LE3 LE2
Initial Value 0 0 0 0 0 0 All 0
R/W R/W R/W R/W R/W R/W R/W R
Description Little Endian Select Selects the endian for the corresponding area. 0: Data format of area n is specified as big endian 1: Data format of area n is specified as little endian (n = 7 to 2) Reserved These are read-only bits and cannot be modified.
Rev.2.00 Jun. 28, 2007 Page 140 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.2.10
SRAM Mode Control Register (SRAMCR)
SRAMCR specifies the bus interface of each area in the external address space as a basic bus interface or a byte control SRAM interface. In areas specified as 8-bit access space by ABWCR, the SRAMCR setting is ignored and the byte control SRAM interface cannot be specified.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 BCSEL7 0 R/W 7 0 R 14 BCSEL6 0 R/W 6 0 R 13 BCSEL5 0 R/W 5 0 R 12 BCSEL4 0 R/W 4 0 R 11 BCSEL3 0 R/W 3 0 R 10 BCSEL2 0 R/W 2 0 R 9 BCSEL1 0 R/W 1 0 R 8 BCSEL0 0 R/W 0 0 R
Bit 15 14 13 12 11 10 9 8 7 to 0
Bit Name BCSEL7 BCSEL6 BCSEL5 BCSEL4 BCSEL3 BCSEL2 BCSEL1 BCSEL0
Initial Value 0 0 0 0 0 0 0 0 All 0
R/W R/W R/W R/W R/W R/W R/W R/W R/W R
Description Byte Control SRAM Interface Select Selects the bus interface for the corresponding area. When setting the area n bit to 1, the bus interface selection bits for the corresponding area in BROMCR and MPXCR should be cleared to 0. 0: Area n is basic bus interface 1: Area n is byte control SRAM interface (n = 7 to 0) Reserved These are read-only bits and cannot be modified.
Rev.2.00 Jun. 28, 2007 Page 141 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.2.11
Burst ROM Interface Control Register (BROMCR)
BROMCR specifies the burst ROM interface.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 BSRM0 0 R/W 7 BSRM1 0 R/W 14 BSTS02 0 R/W 6 BSTS12 0 R/W 13 BSTS01 0 R/W 5 BSTS11 0 R/W 12 BSTS00 0 R/W 4 BSTS10 0 R/W 11 0 R 3 0 R 10 0 R 2 0 R 9 BSWD01 0 R/W 1 BSWD11 0 R/W 8 BSWD00 0 R/W 0 BSWD10 0 R/W
Bit 15
Bit Name BSRM0
Initial Value 0
R/W R/W
Description Area 0 Burst ROM Interface Select Selects the area 0 bus interface. When setting this bit to 1, clear the BCSEL0 bit in SRAMCR to 0. 0: Basic bus interface or byte control SRAM interface 1: Burst ROM interface
14 13 12
BSTS02 BSTS01 BSTS00
0 0 0
R/W R/W R/W
Area 0 Burst Cycle Select Specifies the number of burst cycles of area 0 000: 1 cycle 001: 2 cycles 010: 3 cycles 011: 4 cycles 100: 5 cycles 101: 6 cycles 110: 7 cycles 111: 8 cycles
11, 10
All 0
R
Reserved These are read-only bits and cannot be modified.
Rev.2.00 Jun. 28, 2007 Page 142 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Bit 9 8
Bit Name BSWD01 BSWD00
Initial Value 0 0
R/W R/W R/W
Description Area 0 Burst Word Number Select Selects the number of words in burst access to the area 0 burst ROM interface 00: Up to 4 words (8 bytes) 01: Up to 8 words (16 bytes) 10: Up to 16 words (32 bytes) 11: Up to 32 words (64 bytes)
7
BSRM1
0
R/W
Area 1 Burst ROM Interface Select Selects the area 1 bus interface. When setting this bit to 1, clear the BCSEL1 bit in SRAMCR to 0. 0: Basic bus interface or byte control SRAM interface 1: Burst ROM interface
6 5 4
BSTS12 BSTS11 BSTS10
0 0 0
R/W R/W R/W
Area 1 Burst Cycle Select Specifies the number of cycles of area 1 burst cycle 000: 1 cycle 001: 2 cycles 010: 3 cycles 011: 4 cycles 100: 5 cycles 101: 6 cycles 110: 7 cycles 111: 8 cycles
3, 2 1 0
BSWD11 BSWD10
All 0 0 0
R R/W R/W
Reserved These are read-only bits and cannot be modified. Area 1 Burst Word Number Select Selects the number of words in burst access to the area 1 burst ROM interface 00: Up to 4 words (8 bytes) 01: Up to 8 words (16 bytes) 10: Up to 16 words (32 bytes) 11: Up to 32 words (64 bytes)
Rev.2.00 Jun. 28, 2007 Page 143 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.2.12
Address/Data Multiplexed I/O Control Register (MPXCR)
MPXCR specifies the address/data multiplexed I/O interface.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 MPXE7 0 R/W 7 0 R 14 MPXE6 0 R/W 6 0 R 13 MPXE5 0 R/W 5 0 R 12 MPXE4 0 R/W 4 0 R 11 MPXE3 0 R/W 3 0 R 10 0 R 2 0 R 9 0 R 1 0 R 8 0 R 0 ADDEX 0 R/W
Bit 15 14 13 12 11
Bit Name MPXE7 MPXE6 MPXE5 MPXE4 MPXE3
Initial Value 0 0 0 0 0
R/W R/W R/W R/W R/W R/W
Description Address/Data Multiplexed I/O Interface Select Specifies the bus interface for the corresponding area. When setting the area n bit to 1, clear the BCSELn bit in SRAMCR to 0. 0: Area n is specified as a basic interface or a byte control SRAM interface. 1: Area n is specified as an address/data multiplexed I/O interface (n = 7 to 3)
10 to 1 0 ADDEX
All 0 0
R R/W
Reserved These are read-only bits and cannot be modified. Address Output Cycle Extension Specifies whether a wait cycle is inserted for the address output cycle of address/data multiplexed I/O interface. 0: No wait cycle is inserted for the address output cycle 1: One wait cycle is inserted for the address output cycle
Rev.2.00 Jun. 28, 2007 Page 144 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.3
Bus Configuration
Figure 6.4 shows the internal bus configuration of this LSI. The internal bus of this LSI consists of the following three types. * Internal system bus A bus that connects the CPU, DTC, on-chip RAM, internal peripheral bus, and external access bus. * Internal peripheral bus A bus that accesses registers in the bus controller and interrupt controller and registers of peripheral modules such as SCI and timer. * External access cycle A bus that accesses external devices via the external bus interface.
I synchronization CPU DTC
On-chip RAM Internal system bus
Write data buffer
Bus controller, interrupt controller, power-down controller
Write data buffer External access bus
Internal peripheral bus
P synchronization
Peripheral functions
B synchronization
External bus interface
Figure 6.4 Internal Bus Configuration
Rev.2.00 Jun. 28, 2007 Page 145 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.4
Multi-Clock Function and Number of Access Cycles
The internal functions of this LSI operate synchronously with the system clock (I), the peripheral module clock (P), or the external bus clock (B). Table 6.1 shows the synchronization clock and their corresponding functions. Table 6.1 Synchronization Clocks and Their Corresponding Functions
Function Name MCU operating mode Interrupt controller Bus controller CPU DTC Internal memory Clock pulse generator Power down control I/O ports TPU PPG TMR WDT SCI A/D D/A External bus interface
Synchronization Clock I
P
B
The frequency of each synchronization clock (I, P, and B) is specified by the system clock control register (SCKCR) independently. For further details, see section 17, Clock Pulse Generator. There will be cases when P and B are equal to I and when P and B are different from I according to the SCKCR specifications. In any case, access cycles for internal peripheral functions and external space is performed synchronously with P and B, respectively. For example, in an external address access where the frequency rate of I and B is n : 1, the operation is performed in synchronization with B. In this case, external 2-state access space is 2n cycles and external 3-state access space is 3n cycles (no wait cycles is inserted) if the number of access cycles is counted based on I.
Rev.2.00 Jun. 28, 2007 Page 146 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
If the frequencies of I, P and B are different, the start of bus cycle may not synchronize with P or B according to the bus cycle initiation timing. In this case, clock synchronization cycle (Tsy) is inserted at the beginning of each bus cycle. For example, if an external address access occurs when the frequency rate of I and B is n : 1, 0 to n-1 cycles of Tsy may be inserted. If an internal peripheral module access occurs when the frequency rate of I and P is m : 1, 0 to m-1 cycles of Tsy may be inserted. Figure 6.5 shows the external 2-state access timing when the frequency rate of I and B is 4 : 1. Figure 6.6 shows the external 3-state access timing when the frequency rate of I and B is 2 : 1.
Rev.2.00 Jun. 28, 2007 Page 147 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Divided clock synchronization cycle
Tsy T1 T2
I
B
Address CSn
AS
RD
Read
D15 to D8 D7 to D0 LHWR LLWR
Write D15 to D8
D7 to D0 BS RD/WR
Figure 6.5 System Clock: External Bus Clock = 4:1, External 2-State Access
Rev.2.00 Jun. 28, 2007 Page 148 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Divided clock synchronization cycle
Tsy T1 T2 T3
I
B
Address CSn AS RD Read D15 to D8 D7 to D0 LHWR LLWR Write D15 to D8 D7 to D0 BS RD/WR
Figure 6.6 System Clock: External Bus Clock = 2:1, External 3-State Access
Rev.2.00 Jun. 28, 2007 Page 149 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.5
6.5.1
External Bus
Input/Output Pins
Table 6.2 shows the pin configuration of the bus controller and table 6.3 shows the pin functions on each interface. Table 6.2
Name Bus cycle start Address strobe/address hold
Pin Configuration
Symbol BS AS/AH I/O Output Output Function Signal indicating that the bus cycle has started * Strobe signal indicating that the basic bus, byte control SRAM, or burst ROM space is accessed and address output on address bus is enabled Signal to hold the address during access to the address/data multiplexed I/O interface
*
Read strobe
RD
Output
Strobe signal indicating that the basic bus, byte control SRAM, burst ROM, or address/data multiplexed I/O space is being read * * Signal indicating the input or output direction Write enable signal of the SRAM during access to the byte control SRAM space Strobe signal indicating that the basic bus, burst ROM, or address/data multiplexed I/O space is written to, and the upper byte (D15 to D8) of data bus is enabled Strobe signal indicating that the byte control SRAM space is accessed, and the upper byte (D15 to D8) of data bus is enabled
Read/write
RD/WR
Output
Low-high write/lower-upper byte select
LHWR/LUB Output
*
*
Rev.2.00 Jun. 28, 2007 Page 150 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Name
Symbol
I/O
Function * Strobe signal indicating that the basic bus, burst ROM, or address/data multiplexed I/O space is written to, and the lower byte (D7 to D0) of data bus is enabled Strobe signal indicating that the byte control SRAM space is accessed, and the lower byte (D7 to D0) of data bus is enabled
Low-low write/lower-lower byte LLWR/LLB Output select
*
Chip select 0 Chip select 1 Chip select 2 Chip select 3 Chip select 4 Chip select 5 Chip select 6 Chip select 7 Wait Bus request Bus request acknowledge Bus request output
CS0 CS1 CS2 CS3 CS4 CS5 CS6 CS7 WAIT BREQ BACK BREQO
Output Output Output Output Output Output Output Output Input Input Output Output
Strobe signal indicating that area 0 is selected Strobe signal indicating that area 1 is selected Strobe signal indicating that area 2 is selected Strobe signal indicating that area 3 is selected Strobe signal indicating that area 4 is selected Strobe signal indicating that area 5 is selected Strobe signal indicating that area 6 is selected Strobe signal indicating that area 7 is selected Wait request signal when accessing external address space. Request signal for release of bus to external bus master Acknowledge signal indicating that bus has been released to external bus master External bus request signal used when internal bus master accesses external address space in the external-bus released state External bus clock
External bus clock
B
Output
Rev.2.00 Jun. 28, 2007 Page 151 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Table 6.3
Pin Functions in Each Interface
Byte Control SRAM 16 O O O O O O O O O O O O O O O O
Address/Data
Initial State
Single-
Basic Bus 16 O O O O O O O O O O O O O O O O 8 O O O O O O O O O O O O O O O
Burst ROM 16 O O O O O O O O O O 8 O O O O O O O O O
Multiplexed I/O
Pin Name B CS0 CS1 CS2 CS3 CS4 CS5 CS6 CS7 BS RD/WR AS AH RD LHWR/LUB LLWR/LLB WAIT
16
8
Chip
16 O O O O O O O O O O O O O
8 O O O O O O O O O O O O
Remarks
Output Output Output Output
Output Output
Output Output Output Output Output Output
Controlled by WAITE
[Legend] O: Used as a bus control signal : Not used as a bus control signal (used as a port input when initialized)
Rev.2.00 Jun. 28, 2007 Page 152 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.5.2
Area Division
The bus controller divides the 16-Mbyte address space into eight areas, and performs bus control for the external address space in area units. Chip select signals (CS0 to CS7) can be output for each area. Figure 6.7 shows an area division of the 16-Mbyte address space. For details on address map, see section 3, MCU Operating Modes.
H'000000 Area 0 (2 Mbytes) H'1FFFFF H'200000 Area 1 (2 Mbytes) H'3FFFFF H'400000
Area 2 (8 Mbytes)
H'BFFFFF H'C00000 Area 3 (2 Mbytes) H'DFFFFF H'E00000 Area 4 (1 Mbyte) H'EFFFFF H'F00000 Area 5 (1 Mbyte - 8 kbytes) H'FFDFFF H'FFE000 Area 6 H'FFFEFF (8 kbytes - 256 bytes) H'FFFF00 Area 7 (256 bytes) H'FFFFFF 16-Mbyte space
Figure 6.7 Address Space Area Division
Rev.2.00 Jun. 28, 2007 Page 153 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.5.3
Chip Select Signals
This LSI can output chip select signals (CS0 to CS7) for areas 0 to 7. The signal outputs low when the corresponding external address space area is accessed. Figure 6.8 shows an example of CSn (n = 0 to 7) signal output timing. Enabling or disabling of CSn signal output is set by the port function control register (PFCR). For details, see section 8.3, Port Function Controller. In on-chip ROM disabled extended mode, pin CS0 is placed in the output state after a reset. Pins CS1 to CS7 are placed in the input state after a reset and so the corresponding PFCR bits should be set to 1 when outputting signals CS1 to CS7. In on-chip ROM enabled extended mode, pins CS0 to CS7 are all placed in the input state after a reset and so the corresponding PFCR bits should be set to 1 when outputting signals CS0 to CS7. The PFCR can specify multiple CS outputs for a pin. If multiple CSn outputs are specified for a single pin by the PFCR, CS to be output are generated by mixing all the CS signals. In this case, the settings for the external bus interface areas in which the CSn signals are output to a single pin should be the same. Figure 6.9 shows the signal output timing when the CS signals to be output to areas 5 and 6 are output to the same pin.
Bus cycle T1 B T2 T3
Address bus
External address of area n
CSn
Figure 6.8 CSn Signal Output Timing (n = 0 to 7)
Rev.2.00 Jun. 28, 2007 Page 154 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Area 5 access B CS5 CS6 Output waveform
Area 6 access
Address bus
Area 5 access
Area 6 access
Figure 6.9 Timing When CS Signal is Output to the Same Pin 6.5.4 External Bus Interface
The type of the external bus interfaces, bus width, endian format, number of access cycles, and strobe assert/negate timings can be set for each area in the external address space. The bus width and the number of access cycles for both on-chip memory and internal I/O registers are fixed, and are not affected by the external bus settings. (1) Type of External Bus Interface
Four types of external bus interfaces are provided and can be selected in area units. Table 6.4 shows each interface name, description, and area name to be set for each interface. Table 6.5 shows the areas that can be specified for each interface. The initial state of each area is a basic bus interface. Table 6.4
Interface Basic interface Byte control SRAM interface Burst ROM interface Address/data multiplexed I/O interface
Interface Names and Area Names
Description Directly connected to ROM and RAM Area Name Basic bus space
Directly connected to byte SRAM with Byte control SRAM space byte control pin Directly connected to the ROM that allows page access Directly connected to the peripheral LSI that requires address and data multiplexing Burst ROM space Address/data multiplexed I/O space
Rev.2.00 Jun. 28, 2007 Page 155 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Table 6.5
Areas Specifiable for Each Interface
Related Registers SRAMCR Areas 0 O O BROMCR MPXCR O 1 O O O 2 O O 3 O O O 4 O O O 5 O O O 6 O O O 7 O O O
Interface Basic interface Byte control SRAM interface Burst ROM interface Address/data multiplexed I/O interface
(2)
Bus Width
A bus width of 8 or 16 bits can be selected with ABWCR. An area for which an 8-bit bus is selected functions as an 8-bit access space and an area for which a 16-bit bus is selected functions as a 16-bit access space. In addition, the bus width of address/data multiplexed I/O space is 8 bits or 16 bits, and the bus width for the byte control SRAM space is 16 bits. The initial state of the bus width is specified by the operating mode. If all areas are designated as 8-bit access space, 8-bit bus mode is set; if any area is designated as 16-bit access space, 16-bit bus mode is set. (3) Endian Format
Though the endian format of this LSI is big endian, data can be converted into little endian format when reading or writing to the external address space. Areas 7 to 2 can be specified as either big endian or little endian format by the LE7 to LE2 bits in ENDIANCR. The initial state of each area is the big endian format. Note that the data format for the areas used as a program area or a stack area should be big endian.
Rev.2.00 Jun. 28, 2007 Page 156 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
(4) (a)
Number of Access Cycles Basic Bus Interface
The number of access cycles in the basic bus interface can be specified as two or three cycles by the ASTCR. An area specified as 2-state access is specified as 2-state access space; an area specified as 3-state access is specified as 3-state access space. For the 2-state access space, a wait cycle insertion is disabled. For the 3-state access space, a program wait (0 to 7 cycles) specified by WTCRA and WTCRB or an external wait by WAIT can be inserted. In addition, CSACR can extend the assert periods of the chip select signal and address signal. Number of access cycles in the basic bus interface = number of basic cycles (2, 3) + number of program wait cycles (0 to 7) + number of CS extension cycles (0, 1, 2) [+ number of external wait cycles by the WAIT pin] (b) Byte Control SRAM Interface
The number of access cycles in the byte control SRAM interface is the same as that in the basic bus interface. Number of access cycles in byte control SRAM interface = number of basic cycles (2, 3) + number of program wait cycles (0 to 7) + number of CS extension cycles (0, 1, 2) [+ number of external wait cycles by the WAIT pin] (c) Burst ROM Interface
The number of access cycles at full access in the burst ROM interface is the same as that in the basic bus interface. The number of access cycles in the burst access can be specified as one to eight cycles by the BSTS bit in BROMCR. Number of access cycles in the burst ROM interface = number of basic cycles (2, 3) + number of program wait cycles (0 to 7) + number of CS extension cycles (0, 1) [+number of external wait cycles by the WAIT pin] + number of burst access cycles (1 to 8) x number of burst accesses (0 to 63)
Rev.2.00 Jun. 28, 2007 Page 157 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
(d)
Address/data multiplexed I/O interface
The number of access cycles in data cycle of the address/data multiplexed I/O interface is the same as that in the basic bus interface. The number of access cycles in address cycle can be specified as two or three cycles by the ADDEX bit in MPXCR. Number of access cycles in the address/data multiplexed I/O interface = number of address output cycles (2, 3) + number of data output cycles (2, 3) + number of program wait cycles (0 to 7) + number of CS extension cycles (0, 1, 2) [+number of external wait cycles by the WAIT pin] Table 6.6 lists the number of access cycles for each interface. Table 6.6
Basic bus interface
Number of Access Cycles
= = Th [0,1] Th [0,1] Th [0,1] Th [0,1] Th [0,1] Th [0,1] +Th [0,1] +Th [0,1] +T1 [1] +T1 [1] +T1 [1] +T1 [1] +T1 [1] +T1 [1] +T1 [1] +T1 [1] +T2 [1] +T2 [1] +T2 [1] +T2 [1] +T2 [1] +T2 [1] +T2 [1] +T2 [1] +Tpw [0 to 7] +TtW [n] +T3 [1] +Tt [0,1] +Tt [0,1] +Tt [0,1] +Tt [0,1] +Tb [(1 to 8) x m] +Tb [(1 to 8) x m] +Tt [0,1] +Tt [0,1] [2 to 4] [3 to 12 + n] [2 to 4] [3 to 12 + n] [(2 to 3) + (1 to 8) x m] [(3 to 11 + n) + (1 to 8) x m] [4 to 7] [5 to 15 + n]
Byte control SRAM interface
= =
+Tpw [0 to 7]
+TtW [n]
+T3 [1]
Burst ROM interface
= =
+Tpw [0 to 7]
+TtW [n]
+T3 [1]
Address/data multiplexed I/O interface
= Tma [2,3] = Tma [2,3]
+Tpw [0 to 7]
+TtW [n]
+T3 [1]
[Legend] Numbers: Number of access cycles n: Pin wait (0 to ) m: Number of burst accesses (0 to 63)
(e)
Strobe Assert/Negate Timings
The assert and negate timings of the strobe signals can be modified as well as number of access cycles. * Read strobe (RD) in the basic bus interface * Chip select assertion period extension cycles in the basic bus interface
Rev.2.00 Jun. 28, 2007 Page 158 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.5.5 (1)
Area and External Bus Interface Area 0
Area 0 includes on-chip ROM*. All of area 0 is used as external address space in on-chip ROM disabled extended mode, and the space excluding on-chip ROM is external address space in onchip ROM enabled extended mode. When area 0 external address space is accessed, the CS0 signal can be output. Either of the basic bus interface, byte control SRAM interface, or burst ROM interface can be selected for area 0 by bit BSRM0 in BROMCR and bit BCSEL0 in SRAMCR. Table 6.7 shows the external interface of area 0. Note: Applied to the LSI version that incorporates the ROM. Table 6.7
Interface Basic bus interface Byte control SRAM interface Burst ROM interface Setting prohibited
Area 0 External Interface
Register Setting BSRM0 of BROMCR 0 0 1 1 BCSEL0 of SRAMCR 0 1 0 1
(2)
Area 1
In externally extended mode, all of area 1 is external address space. In on-chip ROM enabled extended mode, the space excluding on-chip ROM* is external address space. When area 1 external address space is accessed, the CS1 signal can be output. Either of the basic bus interface, byte control SRAM, or burst ROM interface can be selected for area 1 by bit BSRM1 in BROMCR and bit BCSEL1 in SRAMCR. Table 6.8 shows the external interface of area 1. Note: Applied to the LSI version that incorporates the ROM.
Rev.2.00 Jun. 28, 2007 Page 159 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Table 6.8
Area 1 External Interface
Register Setting
Interface Basic bus interface Byte control SRAM interface Burst ROM interface Setting prohibited
BSRM1 of BROMCR 0 0 1 1
BCSEL1 of SRAMCR 0 1 0 1
(3)
Area 2
In externally extended mode, all of area 2 is external address space. When area 2 external address space is accessed, the CS2 signal can be output. Either the basic bus interface or byte control SRAM interface can be selected for area 2 by bit BCSEL2 in SRAMCR. Table 6.9 shows the external interface of area 2. Table 6.9 Area 2 External Interface
Register Setting Interface Basic bus interface Byte control SRAM interface BCSEL2 of SRAMCR 0 1
(4)
Area 3
In externally extended mode, all of area 3 is external address space. When area 3 external address space is accessed, the CS3 signal can be output. Either of the basic bus interface, byte control SRAM interface, or address/data multiplexed I/O interface can be selected for area 3 by bit MPXE3 in MPXCR and bit BCSEL3 in SRAMCR. Table 6.10 shows the external interface of area 3.
Rev.2.00 Jun. 28, 2007 Page 160 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Table 6.10 Area 3 External Interface
Register Setting Interface Basic bus interface Byte control SRAM interface Address/data multiplexed I/O interface Setting prohibited MPXE3 of MPXCR 0 0 1 1 BCSEL3 of SRAMCR 0 1 0 1
(5)
Area 4
In externally extended mode, all of area 4 is external address space. When area 4 external address space is accessed, the CS4 signal can be output. Either of the basic bus interface, byte control SRAM interface, or address/data multiplexed I/O interface can be selected for area 4 by bit MPXE4 in MPXCR and bit BCSEL4 in SRAMCR. Table 6.11 shows the external interface of area 4. Table 6.11 Area 4 External Interface
Register Setting Interface Basic bus interface Byte control SRAM interface Address/data multiplexed I/O interface Setting prohibited MPXE4 of MPXCR 0 0 1 1 BCSEL4 of SRAMCR 0 1 0 1
(6)
Area 5
Area 5 includes the on-chip RAM and access prohibited spaces. In external extended mode, area 5, other than the on-chip RAM and access-prohibited spaces, is external address space. Note that the on-chip RAM is enabled when the RAME bit in SYSCR are set to 1. If the RAME bit in SYSCR is cleared to 0, the on-chip RAM is disabled and the corresponding addresses are an external address space. For details, see section 3, MCU Operating Modes.
Rev.2.00 Jun. 28, 2007 Page 161 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
When area 5 external address space is accessed, the CS5 signal can be output. Either of the basic bus interface, byte control SRAM interface, or address/data multiplexed I/O interface can be selected for area 5 by the MPXE5 bit in MPXCR and the BCSEL5 bit in SRAMCR. Table 6.12 shows the external interface of area 5. Table 6.12 Area 5 External Interface
Register Setting Interface Basic bus interface Byte control SRAM interface Address/data multiplexed I/O interface Setting prohibited MPXE5 of MPXCR 0 0 1 1 BCSEL5 of SRAMCR 0 1 0 1
(7)
Area 6
Area 6 includes internal I/O registers. In external extended mode, area 6 other than on-chip I/O register area is external address space. When area 6 external address space is accessed, the CS6 signal can be output. Either of the basic bus interface, byte control SRAM interface, or address/data multiplexed I/O interface can be selected for area 6 by the MPXE6 bit in MPXCR and the BCSEL6 bit in SRAMCR. Table 6.13 shows the external interface of area 6. Table 6.13 Area 6 External Interface
Register Setting Interface Basic bus interface Byte control SRAM interface Address/data multiplexed I/O interface Setting prohibited MPXE6 of MPXCR 0 0 1 1 BCSEL6 of SRAMCR 0 1 0 1
Rev.2.00 Jun. 28, 2007 Page 162 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
(8)
Area 7
Area 7 includes internal I/O registers. In external extended mode, area 7 other than internal I/O register area is external address space. When area 7 external address space is accessed, the CS7 signal can be output. Either of the basic bus interface, byte control SRAM interface, or address/data multiplexed I/O interface can be selected for area 7 by the MPXE7 bit in MPXCR and the BCSEL7 bit in SRAMCR. Table 6.14 shows the external interface of area 7. Table 6.14 Area 7 External Interface
Register Setting Interface Basic bus interface Byte control SRAM interface Address/data multiplexed I/O interface Setting prohibited MPXE7 of MPXCR 0 0 1 1 BCSEL7 of SRAMCR 0 1 0 1
6.5.6
Endian and Data Alignment
Data sizes for the CPU and other internal bus masters are byte, word, and longword. The bus controller has a data alignment function, and controls whether the upper byte data bus (D15 to D8) or lower data bus (D7 to D0) is used according to the bus specifications for the area being accessed (8-bit access space or 16-bit access space), the data size, and endian format when accessing external address space.
Rev.2.00 Jun. 28, 2007 Page 163 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
(1)
8-Bit Access Space
With the 8-bit access space, the lower byte data bus (D7 to D0) is always used for access. The amount of data that can be accessed at one time is one byte: a word access is performed as two byte accesses, and a longword access, as four byte accesses. Figures 6.10 and 6.11 illustrate data alignment control for the 8-bit access space. Figure 6.10 shows the data alignment when the data endian format is specified as big endian. Figure 6.11 shows the data alignment when the data endian format is specified as little endian.
Strobe signal
LHWR/LUB LLWR/LLB
RD Data Size Byte Word Longword Access Address n n n Access Count 1 2 4 Bus Cycle 1st 1st 2nd 1st 2nd 3rd 4th Data bus Data Size Byte Byte Byte Byte Byte Byte Byte
D15 D8 D7
7 15 7 31 23 15 7
D0
0 8 0 24 16 8 0
Figure 6.10 Access Sizes and Data Alignment Control for 8-Bit Access Space (Big Endian)
Strobe signal
LHWR/LUB LLWR/LLB
RD Data Size Byte Word Longword Access Address n n n Access Count 1 2 4 Bus Cycle 1st 1st 2nd 1st 2nd 3rd 4th Data bus Data Size Byte Byte Byte Byte Byte Byte Byte
D15 D8 D7
7 7 15 7 15 23 31
D0
0 0 8 0 8 16 24
Figure 6.11 Access Sizes and Data Alignment Control for 8-Bit Access Space (Little Endian)
Rev.2.00 Jun. 28, 2007 Page 164 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
(2)
16-Bit Access Space
With the 16-bit access space, the upper byte data bus (D15 to D8) and lower byte data bus (D7 to D0) are used for accesses. The amount of data that can be accessed at one time is one byte or one word. Figures 6.12 and 6.13 illustrate data alignment control for the 16-bit access space. Figure 6.12 shows the data alignment when the data endian format is specified as big endian. Figure 6.13 shows the data alignment when the data endian format is specified as little endian. In big endian, byte access for an even address is performed by using the upper byte data bus and byte access for an odd address is performed by using the lower byte data bus. In little endian, byte access for an even address is performed by using the lower byte data bus, and byte access for an odd address is performed by using the upper byte data bus.
Strobe signal
LHWR/LUB LLWR/LLB
RD Access Size Byte Access Address
Even (2n) Odd (2n+1) Even (2n) Odd (2n+1)
Access Count 1 1 1 2
Bus Cycle 1st 1st 1st 1st 2nd
Data bus Data Size Byte Byte Word Byte Byte Word Word Byte Word Byte
23 7 7 31 15 0 24 23 87 31 16 15 0 16 0 24 8 15
D15
7
D8 D7
0 7 87 15
D0
0 0 8
Word
Longword
Even (2n) Odd (2n+1)
2
1st 2nd
3
1st 2nd 3rd
Figure 6.12 Access Sizes and Data Alignment Control for 16-Bit Access Space (Big Endian)
Rev.2.00 Jun. 28, 2007 Page 165 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Strobe signal
LHWR/LUB LLWR/LLB
RD Access Size Byte Access Address
Even (2n) Odd (2n+1) Even (2n) Odd (2n+1)
Access Count 1 1 1 2
Bus Cycle 1st 1st 1st 1st 2nd
Data bus Data Size Byte Byte Word Byte Byte Word Word Byte Word Byte
15 31 7 23 7 15 7 0 87 0 15 87 24 23 0 16 15 31 8 24 8 0 16 0
D15
D8 D7
7
D0
0
Word
Longword
Even (2n) Odd (2n+1)
2
1st 2nd
3
1st 2nd 3rd
Figure 6.13 Access Sizes and Data Alignment Control for 16-Bit Access Space (Little Endian)
Rev.2.00 Jun. 28, 2007 Page 166 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.6
Basic Bus Interface
The basic bus interface can be connected directly to the ROM and SRAM. The bus specifications can be specified by the ABWCR, ASTCR, WTCRA, WTCRB, RDNCR, CSACR, and ENDINCR. 6.6.1 Data Bus
Data sizes for the CPU and other internal bus masters are byte, word, and longword. The bus controller has a data alignment function, and controls whether the upper byte data bus (D15 to D8) or lower byte data bus (D7 to D0) is used according to the bus specifications for the area being accessed (8-bit access space or 16-bit access space), the data size, and endian format when accessing external address space. For details, see section 6.5.6, Endian and Data Alignment. 6.6.2 I/O Pins Used for Basic Bus Interface
Table 6.15 shows the pins used for basic bus interface. Table 6.15 I/O Pins for Basic Bus Interface
Name Bus cycle start Address strobe Read strobe Read/write Low-high write Low-low write Chip select 0 to 7 Wait Note: * Symbol BS AS* RD RD/WR LHWR LLWR I/O Output Output Output Output Output Output Function Signal indicating that the bus cycle has started Strobe signal indicating that an address output on the address bus is valid during access Strobe signal indicating the read access Signal indicating the data bus input or output direction Strobe signal indicating that the upper byte (D15 to D8) is valid during write access Strobe signal indicating that the lower byte (D7 to D0) is valid during write access Strobe signal indicating that the area is selected Wait request signal used when an external address space is accessed
CS0 to CS7 Output WAIT Input
When the address/data multiplexed interface is selected, this pin only functions as the AH output and does not function as the AS output.
Rev.2.00 Jun. 28, 2007 Page 167 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.6.3
Basic Timing
This section describes the basic timing when the data is specified as big endian. (1) 16-Bit 2-State Access Space
Figures 6.14 to 6.16 show the bus timing of 16-bit 2-state access space. When accessing 16-bit access space, the upper byte data bus (D15 to D8) is used for even addresses access, and the lower byte data bus (D7 to D0) is used for odd addresses. No wait cycles can be inserted.
Bus cycle
T1
B Address CSn AS RD Read D15 to D8 D7 to D0 LHWR LLWR Write D15 to D8 D7 to D0 BS RD/WR Valid
T2
Valid Invalid
High level
High-Z
Notes: 1. n = 0 to 7 2. When RDNn = 0
Figure 6.14 16-Bit 2-State Access Space Bus Timing (Byte Access for Even Address)
Rev.2.00 Jun. 28, 2007 Page 168 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Bus cycle T1 B T2
Address CSn AS RD D15 to D8 D7 to D0 LHWR LLWR Write D15 to D8 High-Z D7 to D0 BS Valid Invalid
Read
Valid
High level
RD/WR
Notes: 1. n = 0 to 7 2. When RDNn = 0
Figure 6.15 16-Bit 2-State Access Space Bus Timing (Byte Access for Odd Address)
Rev.2.00 Jun. 28, 2007 Page 169 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Bus cycle T1 B T2
Address CSn AS RD D15 to D8 D7 to D0 LHWR LLWR Write D15 to D8 D7 to D0 Valid Valid
Read
Valid
Valid
BS RD/WR
Notes: 1. n = 0 to 7 2. When RDNn = 0
Figure 6.16 16-Bit 2-State Access Space Bus Timing (Word Access for Even Address)
Rev.2.00 Jun. 28, 2007 Page 170 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
(2)
16-Bit 3-State Access Space
Figures 6.17 to 6.19 show the bus timing of 16-bit 3-state access space. When accessing 16-bit access space, the upper byte data bus (D15 to D8) is used for even addresses, and the lower byte data bus (D7 to D0) is used for odd addresses. Wait cycles can be inserted.
Bus cycle
T1
B
T2
T3
Address CSn AS RD
Read
D15 to D8 D7 to D0 LHWR LLWR
High level Valid
Valid Invalid
Write D15 to D8 D7 to D0 BS RD/WR
High-Z
Notes: 1. n = 0 to 7 2. When RDNn = 0
Figure 6.17 16-Bit 3-State Access Space Bus Timing (Byte Access for Even Address)
Rev.2.00 Jun. 28, 2007 Page 171 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Bus cycle
T1
B
T2
T3
Address CSn AS RD Read D15 to D8 D7 to D0 LHWR LLWR D15 to D8 D7 to D0 BS High level Invalid Valid
Write
High-Z Valid
RD/WR
Notes: 1. n = 0 to 7 2. When RDNn = 0
Figure 6.18 16-Bit 3-State Access Space Bus Timing (Word Access for Odd Address)
Rev.2.00 Jun. 28, 2007 Page 172 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Bus cycle
T1 T2 T3
B
Address CSn AS RD
Read D15 to D8 D7 to D0 LHWR LLWR Write D15 to D8 D7 to D0
Valid Valid
Valid Valid
BS
RD/WR
Notes: 1. n = 0 to 7 2. When RDNn = 0
Figure 6.19 16-Bit 3-State Access Space Bus Timing (Word Access for Even Address)
Rev.2.00 Jun. 28, 2007 Page 173 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.6.4
Wait Control
This LSI can extend the bus cycle by inserting wait cycles (Tw) when the external address space is accessed. There are two ways of inserting wait cycles: program wait (Tpw) insertion and pin wait (Ttw) insertion using the WAIT pin. (1) Program Wait Insertion
From 0 to 7 wait cycles can be inserted automatically between the T2 state and T3 state for 3-state access space, according to the settings in WTCRA and WTCRB. (2) Pin Wait Insertion
For 3-state access space, when the WAITE bit in BCR1 is set to 1 and the ICR bit for the corresponding pin is set to 1, wait input by means of the WAIT pin is enabled. When the external address space is accessed in this state, a program wait (Tw) is first inserted according to the WTCRA and WTCRB settings. If the WAIT pin is low at the falling edge of B in the last T2 or Tpw cycle, another Ttw cycle is inserted until the WAIT pin is brought high. The pin wait insertion is effective when the Tw cycles are inserted to seven cycles or more, or when the number of Tw cycles to be inserted is changed according to the external devices. The WAITE bit is common to all areas. For details on ICR, see section 8, I/O ports. Figure 6.20 shows an example of wait cycle insertion timing. After a reset, the 3-state access is specified, the program wait is inserted for seven cycles, and the WAIT input is disabled.
Rev.2.00 Jun. 28, 2007 Page 174 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Wait by program wait
Wait by WAIT pin
T1
B
T1
Tpw
Ttw
Ttw
T3
WAIT
Address
CSn
AS
RD Read Data bus
Read data
LHWR, LLWR Write Data bus Write data
BS
RD/WR
Notes: 1. Upward arrows indicate the timing of WAIT pin sampling. 2. n = 0 to 7 3. RDNn = 0
Figure 6.20 Example of Wait Cycle Insertion Timing
Rev.2.00 Jun. 28, 2007 Page 175 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.6.5
Read Strobe (RD) Timing
The read strobe timing can be modified in area units by setting bits RDN7 to RDN0 in RDNCR to 1. Figure 6.21 shows an example of timing when the read strobe timing is changed in the basic bus 3state access space.
Bus cycle T1 B T2 T3
Address bus
CSn
AS RD RDNn = 0 Data bus
RD RDNn = 1 Data bus
BS
RD/WR
Note: n = 0 to 7
Figure 6.21 Example of Read Strobe Timing
Rev.2.00 Jun. 28, 2007 Page 176 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.6.6
Extension of Chip Select (CS) Assertion Period
Some external I/O devices require a setup time and hold time between address and CS signals and strobe signals such as RD, LHWR, and LLWR. Settings can be made in CSACR to insert cycles in which only the CS, AS, and address signals are asserted before and after a basic bus space access cycle. Extension of the CS assertion period can be set in area units. With the CS assertion extension period in write access, the data setup and hold times are less stringent since the write data is output to the data bus. Figure 6.22 shows an example of the timing when the CS assertion period is extended in basic bus 3-state access space. Both extension cycle Th inserted before the basic bus cycle and extension cycle Tt inserted after the basic bus cycle, or only one of these, can be specified for individual areas. Insertion or noninsertion can be specified for the Th cycle with the upper eight bits (CSXH7 to CSXH0) in CSACR, and for the Tt cycle with the lower eight bits (CSXT7 to CSXT0).
Rev.2.00 Jun. 28, 2007 Page 177 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Bus cycle Th B T1 T2 T3 Tt
Address CSn
AS
RD Read Data bus Read data
LHWR, LLWR Write Data bus Write data
BS
RD/WR
Note: n = 0 to 7
Figure 6.22 Example of Timing when Chip Select Assertion Period is Extended
Rev.2.00 Jun. 28, 2007 Page 178 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.7
Byte Control SRAM Interface
The byte control SRAM interface is a memory interface for outputting a byte select strobe during a read or a write bus cycle. This interface has 16-bit data input/output pins and can be connected to the SRAM that has the upper byte select and the lower byte select strobes such as UB and LB. The operation of the byte control SRAM interface is the same as the basic bus interface except that: the byte select strobes (LUB and LLB) are output from the write strobe output pins (LHWR and LLWR), respectively; the read strobe (RD) negation timing is a half cycle earlier than that in the case where RDNn = 0 in the basic bus interface regardless of the RDNCR settings; and the RD/WR signal is used as write enable (WE). 6.7.1 Byte Control SRAM Space Setting
Byte control SRAM interface can be specified for areas 0 to 7. Each area can be specified as byte control SRAM interface by setting bits BCSELn (n = 0 to 7) in SRAMCR. For the area specified as burst ROM interface or address/data multiplexed I/O interface, the SRAMCR setting is invalid and byte control SRAM interface cannot be used. 6.7.2 Data Bus
The bus width of the byte control SRAM space can be specified as 16-bit byte control SRAM space according to bits ABWHn and ABWLn (n = 0 to 7) in ABWCR. The area specified as 8-bit access space cannot be specified as the byte control SRAM space. For the 16-bit byte control SRAM space, data bus (D15 to D0) is valid. Access size and data alignment are the same as the basic bus interface. For details, see section 6.5.6, Endian and Data Alignment.
Rev.2.00 Jun. 28, 2007 Page 179 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.7.3
I/O Pins Used for Byte Control SRAM Interface
Table 6.16 shows the pins used for the byte control SRAM interface. In the byte control SRAM interface, write strobe signals (LHWR and LLWR) are output from the byte select strobes. The RD/WR signal is used as a write enable signal. Table 6.16 I/O Pins for Byte Control SRAM Interface
Pin AS/AH When Byte Control SRAM is Specified Name AS Address strobe I/O Function
Output Strobe signal indicating that the address output on the address bus is valid when a basic bus interface space or byte control SRAM space is accessed Output Strobe signal indicating that area n is selected
CSn RD RD/WR
CSn RD RD/WR
Chip select
Read strobe Output Output enable for the SRAM when the byte control SRAM space is accessed Read/write Output Write enable signal for the SRAM when the byte control SRAM space is accessed
LHWR/LUB LUB LLWR/LLB WAIT A23 to A0 D15 to D0 LLB WAIT A23 to A0 D15 to D0
Lower-upper Output Upper byte select when the 16-bit byte byte select control SRAM space is accessed Lower-lower Output Lower byte select when the 16-bit byte byte select control SRAM space is accessed Wait Address pin Data pin Input Wait request signal used when an external address space is accessed
Output Address output pin Input/ output Data input/output pin
Rev.2.00 Jun. 28, 2007 Page 180 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.7.4 (1)
Basic Timing 2-State Access Space
Figure 6.23 shows the bus timing when the byte control SRAM space is specified as a 2-state access space. Data buses used for 16-bit access space is the same as those in basic bus interface. No wait cycles can be inserted.
Bus cycle T1 B Address CSn AS LUB LLB RD/WR RD D15 to D8 D7 to D0 RD/WR RD Write D15 to D8 D7 to D0 BS Note: n = 0 to 7 Valid Valid High level Valid Valid T2
Read
Figure 6.23 16-Bit 2-State Access Space Bus Timing
Rev.2.00 Jun. 28, 2007 Page 181 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
(2)
3-State Access Space
Figure 6.24 shows the bus timing when the byte control SRAM space is specified as a 3-state access space. Data buses used for 16-bit access space is the same as those in the basic bus interface. Wait cycles can be inserted.
Bus cycle T2
T1 B Address CSn AS
T3
LUB LLB RD/WR RD
Read
D15 to D8 D7 to D0 Valid Valid
RD/WR RD
Write
D15 to D8 D7 to D0 BS
High level Valid Valid
Note: n = 0 to 7
Figure 6.24 16-Bit 3-State Access Space Bus Timing
Rev.2.00 Jun. 28, 2007 Page 182 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.7.5
Wait Control
The bus cycle can be extended for the byte control SRAM interface by inserting wait cycles (Tw) in the same way as the basic bus interface. (1) Program Wait Insertion
From 0 to 7 wait cycles can be inserted automatically between T2 cycle and T3 cycle for the 3state access space in area units, according to the settings in WTCRA and WTCRB. (2) Pin Wait Insertion
For 3-state access space, when the WAITE bit in BCR1 is set to 1, the corresponding DDR bit is cleared to 0, and the ICR bit is set to 1, wait input by means of the WAIT pin is enabled. For details on DDR and ICR, see section 8, I/O ports. Figure 6.25 shows an example of wait cycle insertion timing.
Rev.2.00 Jun. 28, 2007 Page 183 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Wait by program wait
Wait by WAIT pin
T1
B
T2
Tpw
Ttw
Ttw
T3
WAIT
Address
CSn
AS
UUB, ULB RD/WR
Read
RD
Data bus RD/WR RD Data bus
Read data
Write
High level Write data
BS
Notes: 1. Upward arrows indicate the timing of WAIT pin sampling. 2. n = 0 to 7
Figure 6.25 Example of Wait Cycle Insertion Timing
Rev.2.00 Jun. 28, 2007 Page 184 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.7.6
Read Strobe (RD)
When the byte control SRAM space is specified, the RDNCR setting for the corresponding space is invalid. The read strobe negation timing is the same timing as when RDNn = 1 in the basic bus interface. 6.7.7 Extension of Chip Select (CS) Assertion Period
In the byte control SRAM interface, the extension cycles can be inserted before and after the bus cycle in the same way as the basic bus interface. For details, see section 6.6.6, Extension of Chip Select (CS) Assertion Period.
6.8
Burst ROM Interface
In this LSI, external address space areas 0 and 1 can be designated as burst ROM space, and burst ROM interfacing performed. The burst ROM interface enables ROM with page access capability to be accessed at high speed. Areas 1 and 0 can be designated as burst ROM space by means of bits BSRM1 and BSRM0 in BROMCR. Consecutive burst accesses of up to 32 words can be performed, according to the setting of bits BSWDn1 and BSWDn0 (n = 0, 1) in BROMCR. From one to eight cycles can be selected for burst access. Settings can be made independently for area 0 and area 1. In the burst ROM interface, burst access covers only CPU read accesses. Other accesses are covered by basic bus interface. 6.8.1 Burst ROM Space Setting
Burst ROM interface can be specified for areas 0 and 1. Areas 0 and 1 can be specified as burst ROM space by setting bits BSRMn (n = 0, 1) in BROMCR.
Rev.2.00 Jun. 28, 2007 Page 185 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.8.2
Data Bus
The bus width of the burst ROM space can be specified as 8-bit or16-bit burst ROM interface space according to the ABWHn and ABWLn bits (n = 0, 1) in ABWCR. For the 8-bit bus width, data bus (D7 to D0) is valid. For the 16-bit bus width, data bus (D15 to D0) is valid. Access size and data alignment are the same as the basic bus interface. For details, see section 6.5.6, Endian and Data Alignment. 6.8.3 I/O Pins Used for Burst ROM Interface
Table 6.17 shows the pins used for the burst ROM interface. Table 6.17 I/O Pins Used for Burst ROM Interface
Name Bus cycle start Address strobe Read strobe Read/write Low-high write Low-low write Chip select 0. 1 Wait Symbol BS AS RD RD/WR LHWR LLWR CS0, CS1 WAIT I/O Output Output Output Output Output Output Output Input Function Signal indicating that the bus cycle has started. Strobe signal indicating that an address output on the address bus is valid during access Strobe signal indicating the read access Signal indicating the data bus input or output direction Strobe signal indicating that the upper byte (D15 to D8) is valid during write access Strobe signal indicating that the lower byte (D7 to D0) is valid during write access Strobe signal indicating that the area is selected Wait request signal used when an external address space is accessed
Rev.2.00 Jun. 28, 2007 Page 186 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.8.4
Basic Timing
The number of access cycles in the initial cycle (full access) on the burst ROM interface is determined by the basic bus interface settings in ABWCR, ASTCR, WTCRA, WTCRB, and bits CSXHn in CSACR (n = 0 to 7). When area 0 or area 1 designated as burst ROM space is read by the CPU, the settings in RDNCR and bits CSXTn in CSACR (n = 0 to 7) are ignored. From one to eight cycles can be selected for the burst cycle, according to the settings of bits BSTS02 to BSTS00 and BSTS12 to BSTS10 in BROMCR. Wait cycles cannot be inserted. In addition, 4-word, 8-word, 16-word, or 32-word consecutive burst access can be performed according to the settings of BSTS01, BSTS00, BSTS11, and BSTS10 bits in BROMCR. The basic access timing for burst ROM space is shown in figures 6.26 and 6.27.
Full access Burst access
T1
B Upper address bus Lower address bus CSn
T2
T3
T1
T2
T1
T2
AS
RD
Data bus
BS
RD/WR
Note: n = 1, 0
Figure 6.26 Example of Burst ROM Access Timing (ASTn = 1, Two Burst Cycles)
Rev.2.00 Jun. 28, 2007 Page 187 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Full access T1 T2 T1
Burst access T1
B Upper address bus Lower address bus
CSn
AS
RD
Data bus
BS
RD/WR
Note: n = 1, 0
Figure 6.27 Example of Burst ROM Access Timing (ASTn = 0, One Burst Cycle)
Rev.2.00 Jun. 28, 2007 Page 188 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.8.5
Wait Control
As with the basic bus interface, either program wait insertion or pin wait insertion by the WAIT pin can be used in the initial cycle (full access) on the burst ROM interface. See section 6.6.4, Wait Control. Wait cycles cannot be inserted in a burst cycle. 6.8.6 Read Strobe (RD) Timing
When the burst ROM space is read by the CPU, the RDNCR setting for the corresponding space is invalid. The read strobe negation timing is the same timing as when RDNn = 0 in the basic bus interface. 6.8.7 Extension of Chip Select (CS) Assertion Period
In the burst ROM interface, the extension cycles can be inserted in the same way as the basic bus interface. For the burst ROM space, the burst access can be enabled only in read access by the CPU. In this case, the setting of the corresponding CSXTn bit in CSACR is ignored and an extension cycle can be inserted only before the full access cycle. Note that no extension cycle can be inserted before or after the burst access cycles. In read accesses by the CPU, the burst ROM space is equivalent to the basic bus interface space. Accordingly, extension cycles can be inserted before and after the burst access cycles.
6.9
Address/Data Multiplexed I/O Interface
If areas 3 to 7 of external address space are specified as address/data multiplexed I/O space in this LSI, the address/data multiplexed I/O interface can be performed. In the address/data multiplexed I/O interface, peripheral LSIs that require the multiplexed address/data can be connected directly to this LSI. 6.9.1 Address/Data Multiplexed I/O Space Setting
Address/data multiplexed I/O interface can be specified for areas 3 to 7. Each area can be specified as the address/data multiplexed I/O space by setting bits MPXEn (n = 3 to 7) in MPXCR.
Rev.2.00 Jun. 28, 2007 Page 189 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.9.2
Address/Data Multiplex
In the address/data multiplexed I/O space, data bus is multiplexed with address bus. Table 6.18 shows the relationship between the bus width and address output. Table 6.18 Address/Data Multiplex
Data Pins Bus Width 8 bits Cycle Address Data 16 bits Address Data PI7 A15 PI6 A14 PI5 A13 PI4 A12 PI3 A11 PI2 A10 PI1 A9 D9 PI0 A8 D8 PH7 PH6 PH5 PH4 PH3 PH2 PH1 PH0 A7 D7 A7 D7 A6 D6 A6 D6 A5 D5 A5 D5 A4 D4 A4 D4 A3 D3 A3 D3
A2 D2 A2 D2
A1 D1 A1 D1
A0 D0 A0 D0
D15 D14 D13 D12 D11 D10
6.9.3
Data Bus
The bus width of the address/data multiplexed I/O space can be specified for either 8-bit access space or 16-bit access space by the ABWHn and ABWLn bits (n = 3 to 7) in ABWCR. For the 8-bit access space, D7 to D0 are valid for both address and data. For 16-bit access space, D15 to D0 are valid for both address and data. If the address/data multiplexed I/O space is accessed, the corresponding address will be output to the address bus. For details on access size and data alignment, see section 6.5.6, Endian and Data Alignment.
Rev.2.00 Jun. 28, 2007 Page 190 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.9.4
I/O Pins Used for Address/Data Multiplexed I/O Interface
Table 6.19 shows the pins used for the address/data multiplexed I/O Interface. Table 6.19 I/O Pins for Address/Data Multiplexed I/O Interface
When Byte Control SRAM is Specified CSn AH* RD LHWR
Pin CSn AS/AH RD LHWR/LUB
Name Chip select Address hold Read strobe
I/O Output Output Output
Function Chip select (n = 3 to 7) when area n is specified as the address/data multiplexed I/O space Signal to hold an address when the address/data multiplexed I/O space is specified Signal indicating that the address/data multiplexed I/O space is being read Strobe signal indicating that the upper bytes (D15 to D8) is valid when the address/data multiplexed I/O space is written Strobe signal indicating that the lower bytes (D7 to D0) is valid when the address/data multiplexed I/O space is written Address and data multiplexed pins for the address/data multiplexed I/O space. Only D7 to D0 are valid when the 8-bit space is specified. D15 to D0 are valid when the 16-bit space is specified.
Low-high write Output
LLWR/LLB
LLWR
Low-low write
Output
D15 to D0
D15 to D0
Address/data
Input/ output
A23 to A0 WAIT BS RD/WR
A23 to A0 WAIT BS RD/WR
Address Wait
Output Input
Address output pin Wait request signal used when the external address space is accessed Signal to indicate the bus cycle start Signal indicating the data bus input or output direction
Bus cycle start Output Read/write Output
Note:
*
The AH output is multiplexed with the AS output. At the timing that an area is specified as address/data multiplexed I/O, this pin starts to function as the AH output meaning that this pin cannot be used as the AS output. At this time, when other areas set to the basic bus interface is accessed, this pin does not function as the AS output. Until an area is specified as address/data multiplexed I/O, be aware that this pin functions as the AS output.
Rev.2.00 Jun. 28, 2007 Page 191 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.9.5
Basic Timing
The bus cycle in the address/data multiplexed I/O interface consists of an address cycle and a data cycle. The data cycle is based on the basic bus interface timing specified by the ABWCR, ASTCR, WTCRA, WTCRB, RDNCR, and CSACR. Figures 6.28 and 6.29 show the basic access timings.
Address cycle Tma1 B Address bus Tma2 T1 Data cycle T2
CSn AH RD Read D7 to D0 LLWR Write D7 to D0 Address Write data Address Read data
BS
RD/WR
Note: n = 3 to 7
Figure 6.28 8-Bit Access Space Access Timing (ABWHn = 1, ABWLn = 1)
Rev.2.00 Jun. 28, 2007 Page 192 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Bus cycle Address cycle Tma1 B Address bus Tma2 T1 Data cycle T2
CSn AH RD Read D15 to D0 LHWR LLWR Address Read data
Write
D15 to D0
Address
Write data
BS RD/WR
Note: n = 3 to 7
Figure 6.29 16-Bit Access Space Access Timing (ABWHn = 0, ABWLn = 1)
Rev.2.00 Jun. 28, 2007 Page 193 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.9.6
Address Cycle Control
An extension cycle (Tmaw) can be inserted between Tma1 and Tma2 cycles to extend the AH signal output period by setting the ADDEX bit in MPXCR. By inserting the Tmaw cycle, the address setup for AH and the AH minimum pulse width can be assured. Figure 6.30 shows the access timing when the address cycle is three cycles.
Address cycle Tma1 B Address bus Tmaw Tma2 T1 Data cycle T2
CSn AH RD Read D15 to D0 LHWR LLWR Address Read data
Write
D15 to D0
Address
Write data
BS RD/WR
Note: n = 3 to 7
Figure 6.30 Access Timing of 3 Address Cycles (ADDEX = 1)
Rev.2.00 Jun. 28, 2007 Page 194 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.9.7
Wait Control
In the data cycle of the address/data multiplexed I/O interface, program wait insertion and pin wait insertion by the WAIT pin are enabled in the same way as in the basic bus interface. For details, see section 6.6.4, Wait Control. Wait control settings do not affect the address cycles. 6.9.8 Read Strobe (RD) Timing
In the address/data multiplexed I/O interface, the read strobe timing of data cycles can be modified in the same way as in basic bus interface. For details, see section 6.6.5, Read Strobe (RD) Timing. Figure 6.31 shows an example when the read strobe timing is modified.
Address cycle Tma1 B Address bus Tma2 Data cycle T1 T2
CSn AH RD RDNn = 0 D7 to D0 RD RDNn = 1 D7 to D0 Address Read data Address Read data
BS RD/WR
Note: n = 3 to 7
Figure 6.31 Read Strobe Timing
Rev.2.00 Jun. 28, 2007 Page 195 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.9.9
Extension of Chip Select (CS) Assertion Period
In the address/data multiplexed interface, the extension cycles can be inserted before and after the bus cycle. For details, see section 6.6.6, Extension of Chip Select (CS) Assertion Period. Figure 6.32 shows an example of the chip select (CS) assertion period extension timing.
Bus cycle Address cycle Tma1 B Address bus CSn AH RD Read D15 to D0 LHWR Write LLWR Address Read data Tma2 Th T1 Data cycle T2 Tt
D15 to D0 BS RD/WR
Address
Write data
Note: n = 3 to 7
Figure 6.32 Chip Select (CS) Assertion Period Extension Timing in Data Cycle When consecutively reading from the same area connected to a peripheral LSI whose data hold time is long, data outputs from the peripheral LSI and this LSI may conflict. Inserting the chip select assertion period extension cycle after the access cycle can avoid the data conflict.
Rev.2.00 Jun. 28, 2007 Page 196 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Figure 6.33 shows an example of the operation. In the figure, both bus cycles A and B are read access cycles to the address/data multiplexed I/O space. An example of the data conflict is shown in (a), and an example of avoiding the data conflict by the CS assertion period extension cycle in (b).
Bus cycle A B Address bus CS AH RD Data bus Data conflict Bus cycle B
Data hold time is long.
(a) Without CS assertion period extension cycle (CSXTn = 0) Bus cycle A Bus cycle B
B Address bus CS AH RD Data bus
(b) With CS assertion period extension cycle (CSXTn = 1)
Figure 6.33 Consecutive Read Accesses to Same Area (Address/Data Multiplexed I/O Space)
Rev.2.00 Jun. 28, 2007 Page 197 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.10
Idle Cycle
In this LSI, idle cycles can be inserted between the consecutive external accesses. By inserting the idle cycle, data conflicts between ROM read cycle whose output floating time is long and an access cycle from/to high-speed memory or I/O interface can be prevented. 6.10.1 Operation
When this LSI consecutively accesses external address space, it can insert an idle cycle between bus cycles in the following three cases. These conditions are determined by the sequence of read and write and previously accessed area. 1. When read cycles of different areas in the external address space occur consecutively 2. When an external write cycle occurs immediately after an external read cycle 3. When an external read cycle occurs immediately after an external write cycle Up to four idle cycles can be inserted under the conditions shown above. The number of idle cycles to be inserted should be specified to prevent data conflicts between the output data from a previously accessed device and data from a subsequently accessed device. Under conditions 1 and 2, which are the conditions to insert idle cycles after read, the number of idle cycles can be selected from setting A specified by the bits IDLCA1 and IDLCA0 in IDLCR or setting B specified by the bits IDLCB1 and IDLCB0 in IDLCR: Setting A can be selected from one to four cycles, and setting B can be selected from one or two to four cycles. Setting A or B can be specified for each area by setting the bits IDLSEL7 to IDLSEL0 in IDLCR. Note that the bits IDLSEL7 to IDLSEL0 correspond to the previously accessed area of the consecutive accesses. The number of idle cycles to be inserted under condition 3, which is a condition to insert idle cycles after write, can be determined by setting A as described above. After the reset release, IDLCR is initialized to four idle cycle insertion under all conditions 1 to 3 shown above.
Rev.2.00 Jun. 28, 2007 Page 198 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Table 6.20 shows the correspondence between conditions 1 to 3 and number of idle cycles to be inserted for each area. Table 6.21 shows the correspondence between the number of idle cycles to be inserted specified by settings A and B, and number of cycles to be inserted. Table 6.20 Number of Idle Cycle Insertion Selection in Each Area
Bit Settings IDLSn Insertion Condition n Setting 0 1 IDLSELn 0 1 Write after read 0 0 1 0 1 Read after write 2 0 1 [Legend] A: Number of idle cycle insertion A is selected. B: Number of idle cycle insertion B is selected. Invalid: No idle cycle is inserted for the corresponding condition. A B A B A B A B A B A B 0 Area for Previous Access 1 2 3 4 5 6 7
Consecutive reads in different areas 1
Invalid A B A B A B A B A B
Invalid A B A B A B A B A B
Invalid A
Table 6.21 Number of Idle Cycle Insertions
Bit Settings A IDLCA1 0 0 1 1 IDLCA0 0 1 0 1 IDLCB1 0 0 1 1 B IDLCB0 0 1 0 1 Number of Cycles 0 1 2 3 4
Rev.2.00 Jun. 28, 2007 Page 199 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
(1)
Consecutive Reads in Different Areas
If consecutive reads in different areas occur while bit IDLS1 in IDLCR is set to 1, idle cycles specified by bits IDLCA1 and IDLCA0 when bit IDSELn in IDLCR is cleared to 0, or bits IDLCB1 and IDLCB0 when bit IDLSELn is set to 1 are inserted at the start of the second read cycle (n = 0 to 7). Figure 6.34 shows an example of the operation in this case. In this example, bus cycle A is a read cycle for ROM with a long output floating time, and bus cycle B is a read cycle for SRAM, each being located in a different area. In (a), an idle cycle is not inserted, and a conflict occurs in bus cycle B between the read data from ROM and that from SRAM. In (b), an idle cycle is inserted, and a data conflict is prevented.
Bus cycle A T1 B T2 T3 Bus cycle B T1 T2 Bus cycle A T1 T2 T3 Bus cycle B Ti T1 T2
Address bus CS (area A) CS (area B) RD Data bus Data conflict
Data hold time is long
(a) No idle cycle inserted (IDLS1 = 0)
(b) Idle cycle inserted (IDLS1 = 1, IDLSELn = 0, IDLCA1 = 0, IDLCA0 = 0)
Figure 6.34 Example of Idle Cycle Operation (Consecutive Reads in Different Areas)
Rev.2.00 Jun. 28, 2007 Page 200 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
(2)
Write after Read
If an external write occurs after an external read while bit IDLS0 in IDLCRis set to 1, idle cycles specified by bits IDLCA1 and IDLCA0 when bit IDSELn in IDLCR is cleared to 0 when IDLSELn = 0,or bits IDLCB1 and IDLCB0 when IDLSELn is set to 1 are inserted at the start of the write cycle (n = 0 to 7). Figure 6.35 shows an example of the operation in this case. In this example, bus cycle A is a read cycle for ROM with a long output floating time, and bus cycle B is a CPU write cycle. In (a), an idle cycle is not inserted, and a conflict occurs in bus cycle B between the read data from ROM and the CPU write data. In (b), an idle cycle is inserted, and a data conflict is prevented.
Bus cycle A T1 B T2 T3 Bus cycle B T1 T2 Bus cycle A T1 T2 T3 Bus cycle B Ti T1 T2
Address bus CS (area A) CS (area B)
RD LLWR Data bus
Data conflict
Data hold time is long.
(a) No idle cycle inserted (IDLS0 = 0)
(b) Idle cycle inserted (IDLS0 = 1, IDLSELn = 0, IDLCA1 = 0, IDLCA0 = 0)
Figure 6.35 Example of Idle Cycle Operation (Write after Read)
Rev.2.00 Jun. 28, 2007 Page 201 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
(3)
Read after Write
If an external read occurs after an external write while bit IDLS2 in IDLCR is set to 1, idle cycles specified by bits IDLCA1 and IDLCA0 are inserted at the start of the read cycle (n = 0 to 7). Figure 6.36 shows an example of the operation in this case. In this example, bus cycle A is a CPU write cycle and bus cycle B is a read cycle from the SRAM. In (a), an idle cycle is not inserted, and a conflict occurs in bus cycle B between the CPU write data and read data from an SRAM device. In (b), an idle cycle is inserted, and a data conflict is prevented.
Bus cycle A T1 B Address bus CS (area A) CS (area B) RD T2 T3 Bus cycle B T1 T2 Bus cycle A T1 T2 T3 Bus cycle B Ti T1 T2
LLWR Data bus Data conflict
Output floating time is large
(a) No idle cycle inserted (IDLS2 = 0)
(b) Idle cycle inserted (IDLS2 = 1, IDLCA1 = 0, IDLCA0 = 0)
Figure 6.36 Example of Idle Cycle Operation (Read after Write)
Rev.2.00 Jun. 28, 2007 Page 202 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
(4)
External NOP Cycles and Idle Cycles
In consecutive external bus accesses, in which even if the cycles that access no external space (external NOP cycles) exist, the condition of inserting idle cycles is effective. In this case, the external NOP cycles are counted as a part of the idle cycles. Figure 6.37 shows an example of external NOP and idle cycle insertion.
No external access Idle cycle (NOP) (remaining) Ti Ti
Preceding bus cycle T1 B T2 Tpw T3
Following bus cycle T1 T2 Tpw T3
Address bus CS (area A) CS (area B) RD
Data bus
Specified number of idle cycles or more including no external access cycles (NOP) (Condition: Number of idle cycles to be inserted when different reads continue: 4 cycles)
Figure 6.37 Idle Cycle Insertion Example
Rev.2.00 Jun. 28, 2007 Page 203 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
(5)
Relationship between Chip Select (CS) Signal and Read (RD) Signal
Depending on the system's load conditions, the RD signal may lag behind the CS signal. An example is shown in figure 6.38. In this case, with the setting for no idle cycle insertion (a), there may be a period of overlap between the RD signal in bus cycle A and the CS signal in bus cycle B. Setting idle cycle insertion, as in (b), however, will prevent any overlap between the RD and CS signals. In the initial state after reset release, idle cycle indicated in (b) is set.
Bus cycle A T1 B T2 T3 Bus cycle B T1 T2 Bus cycle A T1 T2 T3 Bus cycle B Ti T1 T2
Address bus CS (area A) CS (area B) RD
Overlap time may occur between the CS (area B) and RD (a) No idle cycle inserted (IDLS1 = 0) (b) Idle cycle inserted (IDLS1 = 1, IDLSELn = 0, IDLCA1 = 0, IDLCA0 = 0)
Figure 6.38 Relationship between Chip Select (CS) and Read (RD)
Rev.2.00 Jun. 28, 2007 Page 204 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Table 6.22 Idle Cycles in Mixed Accesses to Normal Space
Previous Access Next Access IDLS 2 1 0 1 0 IDLSEL 7 to 0 0 1 0 0 1 1 1 IDLCA 0 0 1 0 1 0 0 1 1 Normal space Normal read space write 0 1 0 0 0 1 1 1 0 1 0 1 0 0 1 1 Normal space Normal write space read 0 1 0 0 1 1 0 1 0 1 0 1 0 1 0 1 0 1 IDLCB 1 0 Idle Cycle Disabled 1 cycle inserted 2 cycles inserted 3 cycles inserted 4 cycles inserted 0 cycle inserted 2 cycle inserted 3 cycles inserted 4 cycles inserted Disabled 1 cycle inserted 2 cycles inserted 3 cycles inserted 4 cycles inserted 0 cycle inserted 2 cycle inserted 3 cycles inserted 4 cycles inserted Disabled 1 cycle inserted 2 cycles inserted 3 cycles inserted 4 cycles inserted
Normal space Normal read space read
Rev.2.00 Jun. 28, 2007 Page 205 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.10.2
Pin States in Idle Cycle
Table 6.23 shows the pin states in an idle cycle. Table 6.23 Pin States in Idle Cycle
Pins A23 to A0 D15 to D0 CSn (n = 7 to 0) AS RD BS RD/WR AH LHWR, LLWR Pin State Contents of following bus cycle High impedance High High High High High Low High
Rev.2.00 Jun. 28, 2007 Page 206 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.11
Bus Release
This LSI can release the external bus in response to a bus request from an external device. In the external bus released state, internal bus masters continue to operate as long as there is no external access. In addition, in the external bus released state, the BREQO signal can be driven low to output a bus request externally. 6.11.1 Operation
In external extended mode, when the BRLE bit in BCR1 is set to 1, and the ICR bit for the corresponding pin is set to 1, the bus can be released to the external. Driving the BREQ pin low issues an external bus request to this LSI. When the BREQ pin is sampled, at the prescribed timing, the BACK pin is driven low, and the address bus, data bus, and bus control signals are placed in the high-impedance state, establishing the external bus released state. For details on DDR and ICR, see section 8, I/O Ports. In the external bus released state, the CPU and DTC can access the internal space using the internal bus. When either the CPU or DTC attempts to access the external address space, it temporarily defers initiation of the bus cycle, and waits for the bus request from the external bus master to be canceled. In the external bus released state, when write access to SCKCR is granted to set the clock frequency, the current setting for the clock frequency is deferred until the bus request of the external bus master is canceled. For details of the SCKCR, see section 17, Clock Pulse Generator. If the BREQOE bit in BCR1is set to 1, the BREQO pin can be driven low when any of the following requests are issued, to request cancellation of the bus request externally. * When either the CPU or DTC attempts to access the external address space * When a SLEEP instruction is executed to place the chip in software standby mode or allmodule-clock-stop mode * When write access to SCKCR is granted to set the clock frequency If an external bus release request and external access occur simultaneously, the priority is as follows: (High) External bus release > External access by CPU or DTC (Low)
Rev.2.00 Jun. 28, 2007 Page 207 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.11.2
Pin States in External Bus Released State
Table 6.24 shows pin states in the external bus released state. Table 6.24 Pin States in Bus Released State
Pins A23 to A0 D15 to D0 BS CSn (n = 7 to 0) AS AH RD/WR RD LUB, LLB LHWR, LLWR Pin State High impedance High impedance High impedance High impedance High impedance High impedance High impedance High impedance High impedance High impedance
Rev.2.00 Jun. 28, 2007 Page 208 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.11.3
Transition Timing
Figure 6.39 shows the timing for transition to the bus released state.
External access cycle T1 B T2
External bus released state
CPU cycle
Address bus Data bus CSn AS RD LHWR, LLWR BREQ BACK BREQO
Hi-Z Hi-Z Hi-Z
Hi-Z Hi-Z
Hi-Z
[1]
[2]
[3]
[4]
[7]
[5]
[8]
[6]
[1] A low level of the BREQ signal is sampled at the rising edge of the B signal. [2] The bus control signals are driven high at the end of the external access cycle. It takes two cycles or more after the low level of the BREQ signal is sampled. [3] The BACK signal is driven low, releasing bus to the external bus master. [4] The BREQ signal state sampling is continued in the external bus released state. [5] A high level of the BREQ signal is sampled. [6] The BREQ signal is driven high, ending external bus release cycle one cycle later. [7] When the external space is accessed by an internal bus master during external bus released while the BREQOE bit is set to 1, the BREQO signal goes low. [8] Normally the BREQO signal goes high at the rising edge of the BACK signal.
Figure 6.39 Bus Released State Transition Timing
Rev.2.00 Jun. 28, 2007 Page 209 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.12
6.12.1
Internal Bus
Access to Internal Address Space
The internal address spaces of this LSI are the on-chip RAM space and register space for the onchip peripheral modules. The number of cycles necessary for access differs according the space. Table 6.25 shows the number of access cycles for each on-chip memory space. Table 6.25 Number of Access Cycles for On-Chip Memory Spaces
Access Space On-chip RAM space Access Read Write Number of Access Cycles One I cycle One I cycle
In access to the registers for on-chip peripheral modules, the number of access cycles differs according to the register to be accessed. When the dividing ratio of the operating clock of a bus master and that of a peripheral module is 1 : n, synchronization cycles using a clock divided by 0 to n-1 are inserted for register access in the same way as for external bus clock division. The number of access cycles to the registers for on-chip peripheral modules is shown in table 6.26. Table 6.26 Number of Access Cycles for Registers of On-Chip Peripheral Modules
Number of Cycles Module to be Accessed Read Write 3I Write Data Buffer Function Disabled
MCU operating mode, clock pulse 2I generator, power-down control registers, interrupt controller, bus controller, and DTC registers I/O port PFCR registers and WDT registers I/O port registers other than PFCR, TPU, PPG, TMR, SCI, A/D, and D/A registers 2P
3P 2P
Disabled Enabled
Rev.2.00 Jun. 28, 2007 Page 210 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.13
6.13.1
Write Data Buffer Function
Write Data Buffer Function for External Data Bus
This LSI has a write data buffer function for the external data bus. Using the write data buffer function enables external writes and internal accesses in parallel. The write data buffer function is made available by setting the WDBE bit to 1 in BCR1. Figure 6.40 shows an example of the timing when the write data buffer function is used. When this function is used, if an external address space write continues for two cycles or longer, and there is an internal access next, an external write only is executed in the first two cycles. However, from the next cycle onward, internal accesses (on-chip memory or internal I/O register read/write) and the external address space write rather than waiting until it ends are executed in parallel.
On-chip memory read External write cycle
Peripheral module read
I Internal address bus
On-chip memory 1
On-chip memory 2
Peripheral module address
T1
T2
T3
B
A23 to A0 External space write
External address
CSn LHWR, LLWR
D15 to D0
Figure 6.40 Example of Timing when Write Data Buffer Function is Used
Rev.2.00 Jun. 28, 2007 Page 211 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.13.2
Write Data Buffer Function for Peripheral Modules
This LSI has a write data buffer function for the peripheral module access. Using the write data buffer function enables peripheral module writes and on-chip memory or external access to be executed in parallel. The write data buffer function is made available by setting the PWDBE bit in BCR2 to 1. As for the peripheral module register space in which the write data buffer function is effective, see table 6.26 in section 6.12. Figure 6.41 shows an example of the timing when the write data buffer function is used. When this function is used, if an internal I/O register write continues for two cycles or longer and then there is an on-chip RAM, or an external access, internal I/O register write only is performed in the first two cycles. However, from the next cycle onward an internal memory or an external access and internal I/O register write are executed in parallel rather than waiting until it ends.
On-chip memory read Peripheral module write I
Internal address bus P
Internal I/O address bus Internal I/O data bus
Peripheral module address
Figure 6.41 Example of Timing when Peripheral Module Write Data Buffer Function is Used
Rev.2.00 Jun. 28, 2007 Page 212 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.14
Bus Arbitration
This LSI has bus arbiters that arbitrate bus mastership operations (bus arbitration). This LSI incorporates internal access and external access bus arbiters that can be used and controlled independently. The internal bus arbiter handles the CPU and DTC accesses. The external bus arbiter handles the external access by the CPU and DTC and external bus release request (external bus master). The bus arbiters determine priorities at the prescribed timing, and permit use of the bus by means of the bus request acknowledge signal. 6.14.1 Operation
The bus arbiter detects the bus masters' bus request signals, and if the bus is requested, sends a bus request acknowledge signal to the bus master. If there are bus requests from more than one bus master, the bus request acknowledge signal is sent to the one with the highest priority. When a bus master receives the bus request acknowledge signal, it takes possession of the bus until that signal is canceled. The priority of the internal bus arbitration: (High) DTC > CPU (Low) The priority of the external bus arbitration: (High) External bus release request > External access by the CPU and DTC (Low) If the DTC accesses continue, the CPU can be given priority over the DTC to execute the bus cycles alternatively between them by setting the IBCCS bit in BCR2. An internal bus access by internal bus masters and external bus release can be executed in parallel.
Rev.2.00 Jun. 28, 2007 Page 213 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
6.14.2
Bus Transfer Timing
Even if a bus request is received from a bus master with a higher priority over that of the bus master that has taken control of the bus and is currently operating, the bus is not necessarily transferred immediately. There are specific timings at which each bus master can release the bus. (1) CPU
The CPU is the lowest-priority bus master, and if a bus request is received from the DTC, the bus arbiter transfers the bus to the bus master that issued the request. The timing for transfer of the bus is at the end of the bus cycle. In sleep mode, the bus is transferred synchronously with the clock. Note, however, that the bus cannot be transferred in the following cases. * The word or longword access is performed in some divisions. * Stack handling is performed in multiple bus cycles. * Transfer data read or write by memory transfer instructions, block transfer instructions, or TAS instruction. (In the block transfer instructions, the bus can be transferred in the write cycle and the following transfer data read cycle.) * From the target read to write in the bit manipulation instructions or memory operation instructions. (In an instruction that performs no write operation according to the instruction condition, up to a cycle corresponding the write cycle) (2) DTC
The DTC sends the internal bus arbiter a request for the bus when an activation request is generated. When the DTC accesses an external bus space, the DTC first takes control of the bus from the internal bus arbiter and then requests a bus to the external bus arbiter. Once the DTC takes control of the bus, the DTC continues the transfer processing cycles. If a bus master whose priority is higher than the DTC requests the bus, the DTC transfers the bus to the higher priority bus master. If the IBCSS bit in BCR2 is set to 1, the DTC transfers the bus to the CPU.
Rev.2.00 Jun. 28, 2007 Page 214 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
Note, however, that the bus cannot be transferred in the following cases. * During transfer information read * During the first data transfer * During transfer information write back The DTC releases the bus when the consecutive transfer cycles completed. (3) External Bus Release
When the BREQ pin goes low and an external bus release request is issued while the BRLE bit in BCR1 and the ICR bit of the corresponding pin are set to 1, a bus request is sent to the bus arbiter. External bus release can be performed on completion of an external bus cycle.
6.15
Bus Controller Operation in Reset
In a reset, this LSI, including the bus controller, enters the reset state immediately, and any executing bus cycle is aborted.
6.16
(1)
Usage Notes
Setting Registers
The BSC registers must be specified before accessing the external address space. When activating the external ROM, specify the registers before external accesses other than the instruction fetch from the external ROM are generated. (2) External Bus Release Function and All-Module-Clock-Stop Mode
In this LSI, if the ACSE bit in MSTPCRA is set to 1, and then a SLEEP instruction is executed with the setting for all peripheral module clocks to be stopped (MSTPCR = H'FFFFFFFF) or for operation of the 8-bit timer module alone (MSTPCR = H'F[E to 0]FFFFFF), and a transition is made to the sleep state, the all-module-clock-stop mode is entered in which the clock is also stopped for the bus controller and I/O ports. For details, see section 18, Power-Down States. In this state, the external bus release function is halted. To use the external bus release function in sleep mode, the ACSE bit in MSTPCRA must be cleared to 0. Conversely, if a SLEEP instruction to place the chip in all-module-clock-stop mode is executed in the external bus released state, the transition to all-module-clock-stop mode is deferred and performed until after the bus is recovered.
Rev.2.00 Jun. 28, 2007 Page 215 of 666 REJ09B0311-0200
Section 6 Bus Controller (BSC)
(3)
External Bus Release Function and Software Standby
In this LSI, internal bus master operation does not stop even while the bus is released, as long as the program is running in on-chip RAM, etc., and no external access occurs. If a SLEEP instruction to place the chip in software standby mode is executed while the external bus is released, the transition to software standby mode is deferred and performed after the bus is recovered. Also, since clock oscillation halts in software standby mode, if the BREQ signal goes low in this mode, indicating an external bus release request, the request cannot be answered until the chip has recovered from the software standby mode. Note that BACK and BREQO goes Hi-Z during software standby. (4) BREQO Output Timing
When the BREQOE bit is set to 1 and the BREQO signal is output, both the BREQO and BACK signals may go low simultaneously. This will occur if the next external access request occurs while internal bus arbitration is in progress after the chip samples a low level of the BREQ signal.
Rev.2.00 Jun. 28, 2007 Page 216 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
Section 7 Data Transfer Controller (DTC)
This LSI includes a data transfer controller (DTC). The DTC can be activated to transfer data by an interrupt request.
7.1
Features
* Transfer possible over any number of channels: Multiple data transfer enabled for one activation source (chain transfer) Chain transfer specifiable after data transfer (when the counter is 0) * Three transfer modes Normal/repeat/block transfer modes selectable Transfer source and destination addresses can be selected from increment/decrement/fixed * Short address mode or full address mode selectable Short address mode Transfer information is located on a 3-longword boundary The transfer source and destination addresses can be specified by 24 bits to select a 16Mbyte address space directly Full address mode Transfer information is located on a 4-longword boundary The transfer source and destination addresses can be specified by 32 bits to select a 4Gbyte address space directly * Size of data for data transfer can be specified as byte, word, or longword The bus cycle is divided if an odd address is specified for a word or longword transfer. The bus cycle is divided if address 4n + 2 is specified for a longword transfer. * A CPU interrupt can be requested for the interrupt that activated the DTC A CPU interrupt can be requested after one data transfer completion A CPU interrupt can be requested after the specified data transfer completion * Read skip of the transfer information specifiable * Writeback skip executed for the fixed transfer source and destination addresses * Module stop state specifiable
Rev.2.00 Jun. 28, 2007 Page 217 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
Figure 7.1 shows a block diagram of the DTC. The DTC transfer information can be allocated to the data area*. When the transfer information is allocated to the on-chip RAM, a 32-bit bus connects the DTC to the on-chip RAM, enabling 32-bit/1-state reading and writing of the DTC transfer information. Note: * When the transfer information is stored in the on-chip RAM, the RAME bit in SYSCR must be set to 1.
Interrupt controller
DTCERA to DTCERH
DTC On-chip RAM MRA
Internal bus (32 bits)
DAR CRA Activation control CRB
DTC activation request vector number CPU interrupt request Interrupt source clear request
8
Interrupt control
External device (memory mapped)
External bus
External memory
Bus interface
Bus controller DTCVBR [Legend] MRA, MRB: SAR: DAR: CRA, CRB: DTCERA to DTCERH: DTCCR: DTCVBR: DTC mode registers A, B DTC source address register DTC destination address register DTC transfer count registers A, B DTC enable registers A to H DTC control register DTC vector base register
REQ ACK
Figure 7.1 Block Diagram of DTC
Rev.2.00 Jun. 28, 2007 Page 218 of 666 REJ09B0311-0200
DTC internal bus
On-chip peripheral module
Peripheral bus
DTCCR
Register control
MRB SAR
Section 7 Data Transfer Controller (DTC)
7.2
Register Descriptions
DTC has the following registers. * * * * * * DTC mode register A (MRA) DTC mode register B (MRB) DTC source address register (SAR) DTC destination address register (DAR) DTC transfer count register A (CRA) DTC transfer count register B (CRB)
These six registers MRA, MRB, SAR, DAR, CRA, and CRB cannot be directly accessed by the CPU. The contents of these registers are stored in the data area as transfer information. When a DTC activation request occurs, the DTC reads a start address of transfer information that is stored in the data area according to the vector address, reads the transfer information, and transfers data. After the data transfer, it writes a set of updated transfer information back to the data area. * DTC enable registers A to H (DTCERA to DTCERH) * DTC control register (DTCCR) * DTC vector base register (DTCVBR)
Rev.2.00 Jun. 28, 2007 Page 219 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.2.1
DTC Mode Register A (MRA)
MRA selects DTC operating mode. MRA cannot be accessed directly by the CPU.
Bit Bit Name Initial Value R/W 7 MD1 Undefined 6 MD0 Undefined 5 Sz1 Undefined 4 Sz0 Undefined 3 SM1 Undefined 2 SM0 Undefined 1 Undefined 0 Undefined
Bit 7 6
Bit Name MD1 MD0
Initial Value
R/W
Description DTC Mode 1 and 0 Specify DTC transfer mode. 00: Normal mode 01: Repeat mode 10: Block transfer mode 11: Setting prohibited
Undefined Undefined
5 4
Sz1 Sz0
Undefined Undefined
DTC Data Transfer Size 1 and 0 Specify the size of data to be transferred. 00: Byte-size transfer 01: Word-size transfer 10: Longword-size transfer 11: Setting prohibited
3 2
SM1 SM0
Undefined Undefined
Source Address Mode 1 and 0 Specify an SAR operation after a data transfer. 0x: SAR is fixed (SAR writeback is skipped) 10: SAR is incremented after a transfer (by 1 when Sz1 and Sz0 = B'00; by 2 when Sz1 and Sz0 = B'01; by 4 when Sz1 and Sz0 = B'10) 11: SAR is decremented after a transfer (by 1 when Sz1 and Sz0 = B'00; by 2 when Sz1 and Sz0 = B'01; by 4 when Sz1 and Sz0 = B'10)
1, 0
Undefined
Reserved The write value should always be 0.
[Legend] X: Don't care
Rev.2.00 Jun. 28, 2007 Page 220 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.2.2
DTC Mode Register B (MRB)
MRB selects DTC operating mode. MRB cannot be accessed directly by the CPU.
Bit Bit Name Initial Value R/W 7 CHNE Undefined 6 CHNS Undefined 5 DISEL Undefined 4 DTS Undefined 3 DM1 Undefined 2 DM0 Undefined 1 Undefined 0 Undefined
Bit 7
Bit Name CHNE
Initial Value
R/W
Description DTC Chain Transfer Enable Specifies the chain transfer. For details, see 7.5.7, Chain Transfer. The chain transfer condition is selected by the CHNS bit. 0: Disables the chain transfer 1: Enables the chain transfer
Undefined
6
CHNS
Undefined
DTC Chain Transfer Select Specifies the chain transfer condition. If the following transfer is a chain transfer, the completion check of the specified transfer count is not performed and activation source flag or DTCER is not cleared. 0: Chain transfer every time 1: Chain transfer only when transfer counter = 0
5
DISEL
Undefined
DTC Interrupt Select When this bit is set to 1, a CPU interrupt request is generated every time after a data transfer ends. When this bit is set to 0, a CPU interrupt request is only generated when the specified number of data transfer ends.
4
DTS
Undefined
DTC Transfer Mode Select Specifies either the source or destination as repeat or block area during repeat or block transfer mode. 0: Specifies the destination as repeat or block area 1: Specifies the source as repeat or block area
Rev.2.00 Jun. 28, 2007 Page 221 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
Bit 3 2
Bit Name DM1 DM0
Initial Value
R/W
Description Destination Address Mode 1 and 0 Specify a DAR operation after a data transfer. 0X: DAR is fixed (DAR writeback is skipped) 10: DAR is incremented after a transfer (by 1 when Sz1 and Sz0 = B'00; by 2 when Sz1 and Sz0 = B'01; by 4 when Sz1 and Sz0 = B'10) 11: SAR is decremented after a transfer (by 1 when Sz1 and Sz0 = B'00; by 2 when Sz1 and Sz0 = B'01; by 4 when Sz1 and Sz0 = B'10)
Undefined Undefined
1, 0
Undefined
Reserved The write value should always be 0.
[Legend] X: Don't care
Rev.2.00 Jun. 28, 2007 Page 222 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.2.3
DTC Source Address Register (SAR)
SAR is a 32-bit register that designates the source address of data to be transferred by the DTC. In full address mode, 32 bits of SAR are valid. In short address mode, the lower 24 bits of SAR are valid and bits 31 to 24 are ignored. At this time, the upper eight bits are filled with the value of bit 23. If a word or longword access is performed while an odd address is specified in SAR or if a longword access is performed while address 4n + 2 is specified in SAR, the bus cycle is divided into multiple cycles to transfer data. For details, see section 7.5.1, Bus Cycle Division. SAR cannot be accessed directly from the CPU. 7.2.4 DTC Destination Address Register (DAR)
DAR is a 32-bit register that designates the destination address of data to be transferred by the DTC. In full address mode, 32 bits of DAR are valid. In short address mode, the lower 24 bits of DAR are valid and bits 31 to 24 are ignored. At this time, the upper eight bits are filled with the value of bit 23. If a word or longword access is performed while an odd address is specified in DAR or if a longword access is performed while address 4n + 2 is specified in DAR, the bus cycle is divided into multiple cycles to transfer data. For details, see section 7.5.1, Bus Cycle Division. DAR cannot be accessed directly from the CPU.
Rev.2.00 Jun. 28, 2007 Page 223 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.2.5
DTC Transfer Count Register A (CRA)
CRA is a 16-bit register that designates the number of times data is to be transferred by the DTC. In normal transfer mode, CRA functions as a 16-bit transfer counter (1 to 65,536). It is decremented by 1 every time data is transferred, and bit DTCEn (n = 15 to 0) corresponding to the activation source is cleared and then an interrupt is requested to the CPU when the count reaches H'0000. The transfer count is 1 when CRA = H'0001, 65,535 when CRA = H'FFFF, and 65,536 when CRA = H'0000. In repeat transfer mode, CRA is divided into two parts: the upper eight bits (CRAH) and the lower eight bits (CRAL). CRAH holds the number of transfers while CRAL functions as an 8-bit transfer counter (1 to 256). CRAL is decremented by 1 every time data is transferred, and the contents of CRAH are sent to CRAL when the count reaches H'00. The transfer count is 1 when CRAH = CRAL = H'01, 255 when CRAH = CRAL = H'FF, and 256 when CRAH = CRAL = H'00. In block transfer mode, CRA is divided into two parts: the upper eight bits (CRAH) and the lower eight bits (CRAL). CRAH holds the block size while CRAL functions as an 8-bit block-size counter (1 to 256 for byte, word, or longword). CRAL is decremented by 1 every time a byte (word or longword) data is transferred, and the contents of CRAH are sent to CRAL when the count reaches H'00. The block size is 1 byte (word or longword) when CRAH = CRAL =H'01, 255 bytes (words or longwords) when CRAH = CRAL = H'FF, and 256 bytes (words or longwords) when CRAH = CRAL =H'00. CRA cannot be accessed directly from the CPU. 7.2.6 DTC Transfer Count Register B (CRB)
CRB is a 16-bit register that designates the number of times data is to be transferred by the DTC in block transfer mode. It functions as a 16-bit transfer counter (1 to 65,536) that is decremented by 1 every time data is transferred, and bit DTCEn (n = 15 to 0) corresponding to the activation source is cleared and then an interrupt is requested to the CPU when the count reaches H'0000. The transfer count is 1 when CRB = H'0001, 65,535 when CRB = H'FFFF, and 65,536 when CRB = H'0000. CRB is not available in normal and repeat modes and cannot be accessed directly by the CPU.
Rev.2.00 Jun. 28, 2007 Page 224 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.2.7
DTC Enable Registers A to H (DTCERA to DTCERH)
DTCER, which is comprised of eight registers, DTCERA to DTCERH, is a register that specifies DTC activation interrupt sources. The correspondence between interrupt sources and DTCE bits is shown in table 7.1. Use bit manipulation instructions such as BSET and BCLR to read or write a DTCE bit. If all interrupts are masked, multiple activation sources can be set at one time (only at the initial setting) by writing data after executing a dummy read on the relevant register.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 DTCE15 0 R/W 7 DTCE7 0 R/W 14 DTCE14 0 R/W 6 DTCE6 0 R/W 13 DTCE13 0 R/W 5 DTCE5 0 R/W 12 DTCE12 0 R/W 4 DTCE4 0 R/W 11 DTCE11 0 R/W 3 DTCE3 0 R/W 10 DTCE10 0 R/W 2 DTCE2 0 R/W 9 DTCE9 0 R/W 1 DTCE1 0 R/W 8 DTCE8 0 R/W 0 DTCE0 0 R/W
Bit 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
Bit Name DTCE15 DTCE14 DTCE13 DTCE12 DTCE11 DTCE10 DTCE9 DTCE8 DTCE7 DTCE6 DTCE5 DTCE4 DTCE3 DTCE2 DTCE1 DTCE0
Initial Value 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W
Description DTC Activation Enable 15 to 0 Setting this bit to 1 specifies a relevant interrupt source to a DTC activation source. [Clearing conditions] * When writing 0 to the bit to be cleared after reading 1 * When the DISEL bit is 1 and the data transfer has ended * When the specified number of transfers have ended These bits are not cleared when the DISEL bit is 0 and the specified number of transfers have not ended
Rev.2.00 Jun. 28, 2007 Page 225 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.2.8
DTC Control Register (DTCCR)
DTCCR specifies transfer information read skip.
Bit Bit Name Initial Value R/W 7 0 R/W 6 0 R/W 5 0 R/W 4 RRS 0 R/W 3 RCHNE 0 R/W 2 0 R 1 0 R 0 ERR 0 R/(W)*
Note: * Only 0 can be written to clear the flag.
Bit 7 to 5
Bit Name
Initial Value All 0
R/W R/W
Description Reserved These bits are always read as 0. The write value should always be 0.
4
RRS
0
R/W
DTC Transfer Information Read Skip Enable Controls the vector address read and transfer information read. A DTC vector number is always compared with the vector number for the previous activation. If the vector numbers match and this bit is set to 1, the DTC data transfer is started without reading a vector address and transfer information. If the previous DTC activation is a chain transfer, the vector address read and transfer information read are always performed. 0: Transfer read skip is not performed. 1: Transfer read skip is performed when the vector numbers match.
3
RCHNE
0
R/W
Chain Transfer Enable After DTC Repeat Transfer Enables/disables the chain transfer while transfer counter (CRAL) is 0 in repeat transfer mode. In repeat transfer mode, the CRAH value is written to CRAL when CRAL is 0. Accordingly, chain transfer may not occur when CRAL is 0. If this bit is set to 1, the chain transfer is enabled when CRAH is written to CRAL. 0: Disables the chain transfer after repeat transfer 1: Enables the chain transfer after repeat transfer
2, 1
All 0
R
Reserved These are read-only bits and cannot be modified.
Rev.2.00 Jun. 28, 2007 Page 226 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
Bit 0
Bit Name ERR
Initial Value 0
R/W
Description
R/(W)* Transfer Stop Flag Indicates that an address error or an NMI interrupt occurs. If an address error or an NMI interrupt occurs, the DTC stops. 0: No interrupt occurs 1: An interrupt occurs [Clearing condition] * When writing 0 after reading 1
Note:
*
Only 0 can be written to clear this flag.
7.2.9
DTC Vector Base Register (DTCVBR)
DTCVBR is a 32-bit register that specifies the base address for vector table address calculation. Bits 31 to 28 and bits 11 to 0 are fixed 0 and cannot be written to. The initial value of DTCVBR is H'00000000.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 0 R/W 0 R/W 0 R/W 0 R/W 0 R 0 R 0 R 0 R 0 R 0 R 0 R 0 R 0 R 0 R 0 R 0 R 0 R 15 0 R 14 0 R 13 0 R 12 0 R/W 11 0 R/W 10 0 R/W 9 0 R/W 8 0 R/W 7 0 R/W 6 0 R/W 5 0 R/W 4 0 R/W 3 0 R/W 2 0 R/W 1 0 R/W 0 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16
7.3
Activation Sources
The DTC is activated by an interrupt request. The interrupt source is selected by DTCER. A DTC activation source can be selected by setting the corresponding bit in DTCER; the CPU interrupt source can be selected by clearing the corresponding bit in DTCER. At the end of a data transfer (or the last consecutive transfer in the case of chain transfer), the activation source interrupt flag or corresponding DTCER bit is cleared.
Rev.2.00 Jun. 28, 2007 Page 227 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.4
Location of Transfer Information and DTC Vector Table
Locate the transfer information in the data area. The start address of transfer information should be located at the address that is a multiple of four (4n). Otherwise, the lower two bits are ignored during access ([1:0] = B'00.) Transfer information can be located in either short address mode (three longwords) or full address mode (four longwords). The DTCMD bit in SYSCR specifies either short address mode (DTCMD = 1) or full address mode (DTCMD = 0). For details, see section 3.2.2, System Control Register (SYSCR). Transfer information located in the data area is shown in figure 7.2. The DTC reads the start address of transfer information from the vector table according to the activation source, and then reads the transfer information from the start address. Figure 7.3 shows correspondences between the DTC vector address and transfer information.
Transfer information in short address mode Lower addresses Start address 0 MRA MRB Chain transfer CRA MRA MRB CRA 4 bytes CRA 4 bytes CRB 1 2 SAR DAR CRB SAR DAR CRB Transfer information for one transfer (3 longwords) Transfer information for the 2nd transfer in chain transfer (3 longwords) Chain transfer 3 Start address 0 Transfer information in full address mode Lower addresses 1 2 3 Transfer information for one transfer (4 longwords)
Reserved (0 write)
MRA MRB
SAR DAR CRA MRA MRB CRB
Reserved (0 write)
SAR DAR
Transfer information for the 2nd transfer in chain transfer (4 longwords)
Figure 7.2 Transfer Information on Data Area
Rev.2.00 Jun. 28, 2007 Page 228 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
Upper: DTCVBR Lower: H'400 + vector number x 4 DTC vector address +4
Vector table Transfer information (1)
Transfer information (1) start address Transfer information (2) start address : : : Transfer information (n) start address 4 bytes Transfer information (n) : : :
Transfer information (2)
+4n
Figure 7.3 Correspondence between DTC Vector Address and Transfer Information Table 7.1 shows correspondence between the DTC activation source and vector address. Table 7.1 Interrupt Sources, DTC Vector Addresses, and Corresponding DTCEs
Vector Number 64 65 66 67 68 69 70 71 72 73 74 75 86 DTC Vector Address Offset H'500 H'504 H'508 H'50C H'510 H'514 H'518 H'51C H'520 H'524 H'528 H'52C H'558 DTCE* DTCEA15 DTCEA14 DTCEA13 DTCEA12 DTCEA11 DTCEA10 DTCEA9 DTCEA8 DTCEA7 DTCEA6 DTCEA5 DTCEA4 DTCEB15 Low Priority High
Origin of Activation Activation Source Source External pin IRQ0 IRQ1 IRQ2 IRQ3 IRQ4 IRQ5 IRQ6 IRQ7 IRQ8 IRQ9 IRQ10 IRQ11 A/D ADI
Rev.2.00 Jun. 28, 2007 Page 229 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
Origin of Activation Activation Source Source TPU_0 TGI0A TGI0B TGI0C TGI0D TPU_1 TPU_2 TPU_3 TGI1A TGI1B TGI2A TGI2B TGI3A TGI3B TGI3C TGI3D TPU_4 TPU_5 TMR_0 TMR_1 TMR_2 TMR_3 SCI_0 SCI_1 SCI_2 SCI_4 Note: * TGI4A TGI4B TGI5A TGI5B CMIA0 CMIB0 CMIA1 CMIB1 CMIA2 CMIB2 CMIA3 CMIB3 RXI0 TXI0 RXI1 TXI1 RXI2 TXI2 RXI4
Vector Number 88 89 90 91 93 94 97 98 101 102 103 104 106 107 110 111 116 117 119 120 122 123 125 126 145 146 149 150 153 154 161
DTC Vector Address Offset H'560 H'564 H'568 H'56C H'574 H'578 H'584 H'588 H'594 H'598 H'59C H'5A0 H'5A8 H'5AC H'5B8 H'5BC H'5D0 H'5D4 H'5DC H'5E0 H'5E8 H'5EC H'5F4 H'5F8 H'644 H'648 H'654 H'658 H'664 H'668 H'684
DTCE* DTCEB13 DTCEB12 DTCEB11 DTCEB10 DTCEB9 DTCEB8 DTCEB7 DTCEB6 DTCEB5 DTCEB4 DTCEB3 DTCEB2 DTCEB1 DTCEB0 DTCEC15 DTCEC14 DTCEC13 DTCEC12 DTCEC11 DTCEC10 DTCEC9 DTCEC8 DTCEC7 DTCEC6 DTCED5 DTCED4 DTCED3 DTCED2 DTCED1 DTCED0 DTCEE13
Priority High
TXI4 162 H'688 DTCEE12 Low The DTCE bits with no corresponding interrupt are reserved, and the write value should always be 0. To leave software standby mode or all-module-clock-stop mode with an interrupt, write 0 to the corresponding DTCE bit.
Rev.2.00 Jun. 28, 2007 Page 230 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.5
Operation
The DTC stores transfer information in the data area. When activated, the DTC reads transfer information that is stored in the data area and transfers data on the basis of that transfer information. After the data transfer, it writes updated transfer information back to the data area. Since transfer information is in the data area, it is possible to transfer data over any required number of channels. There are three transfer modes: normal, repeat, and block. The DTC specifies the source address and destination address in SAR and DAR, respectively. After a transfer, SAR and DAR are incremented, decremented, or fixed independently. Table 7.2 shows the DTC transfer modes. Table 7.2
Transfer Mode Normal Repeat*1 Block*2
DTC Transfer Modes
Size of Data Transferred at One Transfer Request 1 byte/word/longword 1 byte/word/longword Block size specified by CRAH (1 to 256 bytes/words/longwords) Memory Address Increment or Decrement Incremented/decremented by 1, 2, or 4, or fixed Incremented/decremented by 1, 2, or 4, or fixed Incremented/decremented by 1, 2, or 4, or fixed Transfer Count 1 to 65536 1 to 256*3 1 to 65536
Notes: 1. Either source or destination is specified to repeat area. 2. Either source or destination is specified to block area. 3. After transfer of the specified transfer count, initial state is recovered to continue the operation.
Setting the CHNE bit in MRB to 1 makes it possible to perform a number of transfers with a single activation (chain transfer). Setting the CHNS bit in MRB to 1 can also be made to have chain transfer performed only when the transfer counter value is 0. Figure 7.4 shows a flowchart of DTC operation, and table 7.3 summarizes the chain transfer conditions (combinations for performing the second and third transfers are omitted).
Rev.2.00 Jun. 28, 2007 Page 231 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
Start Match & RRS = 1
Vector number comparison Not match | RRS = 0 Read DTC vector Next transfer Read transfer information
Transfer data
Update transfer information
Update the start address of transfer information
Write transfer information
CHNE = 1 Yes No
Transfer counter = 0 or DISEL = 1 Yes No
CHNS = 0 Yes No Transfer counter = 0 Yes No DISEL = 1 No
Yes
Clear activation source flag
Clear DTCER/request an interrupt to the CPU
End
Figure 7.4 Flowchart of DTC Operation
Rev.2.00 Jun. 28, 2007 Page 232 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
Table 7.3
Chain Transfer Conditions
1st Transfer 2nd Transfer Transfer CHNE CHNS DISEL Counter*1 DTC Transfer 0 0 0 0 0 1 0 0 1 Not 0 0* Not 0 0*2
2
Transfer 1 CHNE CHNS DISEL Counter* 0 0 0 1 0 0 0 1 Not 0 0*
2
Ends at 1st transfer Ends at 1st transfer Interrupt request to CPU Ends at 2nd transfer Ends at 2nd transfer Interrupt request to CPU Ends at 1st transfer Ends at 2nd transfer Ends at 2nd transfer Interrupt request to CPU Ends at 1st transfer Interrupt request to CPU
1 1
1 1
0
Not 0 0*
2
0 0 0
1
1
1
Not 0
Notes: 1. CRA in normal mode transfer, CRAL in repeat transfer mode, or CRB in block transfer mode 2. When the contents of the CRAH is written to the CRAL in repeat transfer mode
7.5.1
Bus Cycle Division
When the transfer data size is word and the SAR and DAR values are not a multiple of 2, the bus cycle is divided and the transfer data is read from or written to in bytes. Similarly, when the transfer data size is longword and the SAR and DAR values are not a multiple of 4, the bus cycle is divided and the transfer data is read from or written to in words. Table 7.4 shows the relationship among, SAR, DAR, transfer data size, bus cycle divisions, and access data size. Figure 7.5 shows the bus cycle division example. Table 7.4 Number of Bus Cycle Divisions and Access Size
Specified Data Size SAR and DAR Values Byte (B) Address 4n Address 2n + 1 Address 4n + 2 1 (B) 1 (B) 1 (B) Word (W) 1 (W) 2 (B-B) 1 (W) Longword (LW) 1 (LW) 3 (B-W-B) 2 (W-W)
Rev.2.00 Jun. 28, 2007 Page 233 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
[Example 1: When an odd address and even address are specified in SAR and DAR, respectively, and when the data size of transfer is specified as word]
Clock
DTC activation request
DTC request R Address W
B
B
W
Vector read
Transfer information Data transfer Transfer information read write
[Example 2: When an odd address and address 4n are specified in SAR and DAR, respectively, and when the data size of transfer is specified as longword]
Clock
DTC activation request
DTC request R Address W
B
W
B
L
Vector read
Transfer information read
Data transfer
Transfer information write
[Example 3: When address 4n + 2 and address 4n are specified in SAR and DAR, respectively, and when the data size of transfer is specified as longword]
Clock
DTC activation request
DTC request R Address W
W
W
L
Vector read
Transfer information Data transfer Transfer information read write
Figure 7.5 Bus Cycle Division Example
Rev.2.00 Jun. 28, 2007 Page 234 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.5.2
Transfer Information Read Skip Function
By setting the RRS bit of DTCCR, the vector address read and transfer information read can be skipped. The current DTC vector number is always compared with the vector number of previous activation. If the vector numbers match when RRS = 1, a DTC data transfer is performed without reading the vector address and transfer information. If the previous activation is a chain transfer, the vector address read and transfer information read are always performed. Figure 7.6 shows the transfer information read skip timing. To modify the vector table and transfer information, temporarily clear the RRS bit to 0, modify the vector table and transfer information, and then set the RRS bit to 1 again. When the RRS bit is cleared to 0, the stored vector number is deleted, and the updated vector table and transfer information are read at the next activation.
Clock
DTC activation request
(1)
(2)
DTC request
Transfer information read skip
Address
R
W
R
W
Vector read
Transfer information Data Transfer information read transfer write
Data Transfer information transfer write
Note: Transfer information read is skipped when the activation sources of (1) and (2) (vector numbers) are the same while RRS = 1.
Figure 7.6 Transfer Information Read Skip Timing
Rev.2.00 Jun. 28, 2007 Page 235 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.5.3
Transfer Information Writeback Skip Function
By specifying bit SM1 in MRA and bit DM1 in MRB to the fixed address mode, a part of transfer information will not be written back. This function is performed regardless of short or full address mode. Table 7.5 shows the transfer information writeback skip condition and writeback skipped registers. Note that the CRA and CRB are always written back regardless of the short or full address mode. In addition in full address mode, the writeback of the MRA and MRB are always skipped. Table 7.5
SM1 0 0 1 1
Transfer Information Writeback Skip Condition and Writeback Skipped Registers
DM1 0 1 0 1 SAR Skipped Skipped Written back Written back DAR Skipped Written back Skipped Written back
7.5.4
Normal Transfer Mode
In normal transfer mode, one operation transfers one byte, one word, or one longword of data. From 1 to 65,536 transfers can be specified. The transfer source and destination addresses can be specified as incremented, decremented, or fixed. When the specified number of transfers ends, an interrupt can be requested to the CPU. Table 7.6 lists the register function in normal transfer mode. Figure 7.7 shows the memory map in normal transfer mode. Table 7.6
Register SAR DAR CRA CRB Note: *
Register Function in Normal Transfer Mode
Function Source address Destination address Transfer count A Transfer count B Transfer information writeback is skipped. Written Back Value Incremented/decremented/fixed* Incremented/decremented/fixed* CRA - 1 Not updated
Rev.2.00 Jun. 28, 2007 Page 236 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
Transfer source data area
Transfer destination data area
SAR Transfer
DAR
Figure 7.7 Memory Map in Normal Transfer Mode 7.5.5 Repeat Transfer Mode
In repeat transfer mode, one operation transfers one byte, one word, or one longword of data. By the DTS bit in MRB, either the source or destination can be specified as a repeat area. From 1 to 256 transfers can be specified. When the specified number of transfers ends, the transfer counter and address register specified as the repeat area is restored to the initial state, and transfer is repeated. The other address register is then incremented, decremented, or left fixed. In repeat transfer mode, the transfer counter (CRAL) is updated to the value specified in CRAH when CRAL becomes H'00. Thus the transfer counter value does not reach H'00, and therefore a CPU interrupt cannot be requested when DISEL = 0. Table 7.7 lists the register function in repeat transfer mode. Figure 7.8 shows the memory map in repeat transfer mode.
Rev.2.00 Jun. 28, 2007 Page 237 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
Table 7.7
Register Function in Repeat Transfer Mode
Written Back Value
Register Function SAR Source address
CRAL is not 1
CRAL is 1
Incremented/decremented/fixed DTS =0: Incremented/ * decremented/fixed* DTS = 1: SAR initial value
DAR
Destination address Incremented/decremented/fixed DTS = 0: DAR initial value * DTS =1: Incremented/ decremented/fixed* Transfer count storage Transfer count A Transfer count B * CRAH CRAL - 1 Not updated CRAH CRAH Not updated
CRAH CRAL CRB Note:
Transfer information writeback is skipped.
Transfer source data area (specified as repeat area)
Transfer destination data area
SAR Transfer
DAR
Figure 7.8 Memory Map in Repeat Transfer Mode (When Transfer Source is Specified as Repeat Area)
Rev.2.00 Jun. 28, 2007 Page 238 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.5.6
Block Transfer Mode
In block transfer mode, one operation transfers one block of data. Either the transfer source or the transfer destination is designated as a block area by the DTS bit in MRB. The block size is 1 to 256 bytes (1 to 256 words, or 1 to 256 longwords). When the transfer of one block ends, the block size counter (CRAL) and address register (SAR when DTS = 1 or DAR when DTS = 0) specified as the block area is restored to the initial state. The other address register is then incremented, decremented, or left fixed. From 1 to 65,536 transfers can be specified. When the specified number of transfers ends, an interrupt is requested to the CPU. Table 7.8 lists the register function in block transfer mode. Figure 7.9 shows the memory map in block transfer mode. Table 7.8 Register Function in Block Transfer Mode
Written Back Value DTS =0: Incremented/decremented/fixed* DTS = 1: SAR initial value DAR CRAH CRAL CRB Note: * Destination address Block size storage Block size counter Block transfer counter DTS = 0: DAR initial value DTS =1: Incremented/decremented/fixed* CRAH CRAH CRB - 1
Register Function SAR Source address
Transfer information writeback is skipped.
Transfer source data area
Transfer destination data area (specified as block area)
SAR
1st block
: : :
Transfer Block area DAR
Nth block
Figure 7.9 Memory Map in Block Transfer Mode (When Transfer Destination is Specified as Block Area)
Rev.2.00 Jun. 28, 2007 Page 239 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.5.7
Chain Transfer
Setting the CHNE bit in MRB to 1 enables a number of data transfers to be performed consecutively in response to a single transfer request. Setting the CHNE and CHNS bits in MRB set to 1 enables a chain transfer only when the transfer counter reaches 0. SAR, DAR, CRA, CRB, MRA, and MRB, which define data transfers, can be set independently. Figure 7.10 shows the chain transfer operation. In the case of transfer with CHNE set to 1, an interrupt request to the CPU is not generated at the end of the specified number of transfers or by setting the DISEL bit to 1, and the interrupt source flag for the activation source and DTCER are not affected. In repeat transfer mode, setting the RCHNE bit in DTCCR and the CHNE and CHNS bits in MRB to 1 enables a chain transfer after transfer with transfer counter = 1 has been completed.
Data area
Transfer source data (1) Transfer information stored in user area
Vector table
Transfer destination data (1) DTC vector address Transfer information CHNE = 1 Transfer information CHNE = 0 Transfer source data (2)
Transfer information start address
Transfer destination data (2)
Figure 7.10 Operation of Chain Transfer
Rev.2.00 Jun. 28, 2007 Page 240 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.5.8
Operation Timing
Figures 7.11 to 7.14 show the DTC operation timings.
Clock
DTC activation request
DTC request
Address
R Vector read
W Transfer information write
Transfer Data transfer information read
Figure 7.11 DTC Operation Timing (Example of Short Address Mode in Normal Transfer Mode or Repeat Transfer Mode)
Clock
DTC activation request
DTC request
Address
R Vector read Transfer information read
W
R
W Transfer information write
Data transfer
Figure 7.12 DTC Operation Timing (Example of Short Address Mode in Block Transfer Mode with Block Size of 2)
Rev.2.00 Jun. 28, 2007 Page 241 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
Clock
DTC activation request
DTC request
Address
R Vector read Transfer information read
W Transfer information write Transfer information read
R
W Transfer information write
Data transfer
Data transfer
Figure 7.13 DTC Operation Timing (Example of Short Address Mode in Chain Transfer)
Clock
DTC activation request
DTC request
Address
R Vector read Transfer information read
W
Data Transfer information transfer write
Figure 7.14 DTC Operation Timing (Example of Full Address Mode in Normal Transfer Mode or Repeat Transfer Mode)
Rev.2.00 Jun. 28, 2007 Page 242 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.5.9
Number of DTC Execution Cycles
Table 7.9 shows the execution status for a single DTC data transfer, and table 7.10 shows the number of cycles required for each execution. Table 7.9 DTC Execution Status
Transfer Information Read J Transfer Information Write L Internal Operation N
Mode
Vector Read I
Data Read L
Data Write M
Normal 1 Repeat 1 Block 1 transfer
0*1 0*1 0*1
4*2 4*2 4*2
3*3 3*3 3*3
0*1 0*1 0*1
3*2.3 2*4 3*2.3 2*4 3*2.3 2*4
1*5 1*5 1*5
3*6 3*6
3*P 6 *
2*7 2*7
7
1 1
3*6 3*6
2*7 2*7
7
1 1
1 1
0*1 0*1 0*1
2*P* 1*P 3*P 6 *
2*P* 1*P 1
[Legend] P: Block size (CRAH and CRAL value) Notes: 1. When transfer information read is skipped 2. In full address mode operation 3. In short address mode operation 4. When the SAR or DAR is in fixed mode 5. When the SAR and DAR are in fixed mode 6. When a longword is transferred while an odd address is specified in the address register 7. When a word is transferred while an odd address is specified in the address register or when a longword is transferred while address 4n + 2 is specified
Rev.2.00 Jun. 28, 2007 Page 243 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
Table 7.10 Number of Cycles Required for Each Execution State
OnChip RAM 32 1 1 OnChip ROM 32 1 1 1 1 1 1 1 1 1 1 8 2 2 4 8 2 4 8 On-Chip I/O Registers 16 2 2 2 4 2 2 4 32 2 2 2 2 2 2 2 1 2 8 8 8 2 4 8 2 4 8
Object to be Accessed Bus width Access cycles
Execu- Vector read SI tion status
External Devices 8 3 12 + 4m 12 + 4m 12 + 4m 3+m 4 + 2m 12 + 4m 3+m 4 + 2m 12 + 4m 2 4 4 4 2 2 4 2 2 4 16 3 6 + 2m 6 + 2m 6 + 2m 3+m 3+m 6 + 2m 3+m 3+m 6 + 2m
Transfer information read SJ 1 Transfer information write Sk 1 Byte data read SL Word data read SL Longword data read SL Byte data write SM Word data write SM Longword data write SM Internal operation SN 1 1 1 1 1 1
[Legend] m: Number of wait cycles 0 to 7 (For details, see section 6, Bus Controller (BSC).)
The number of execution cycles is calculated from the formula below. Note that means the sum of all transfers activated by one activation event (the number in which the CHNE bit is set to 1, plus 1). Number of execution cycles = I * SI + (J * SJ + K * SK + L * SL + M * SM) + N * SN 7.5.10 DTC Bus Release Timing
The DTC requests the bus mastership to the bus arbiter when an activation request occurs. The DTC releases the bus after a vector read, transfer information read, a single data transfer, or transfer information writeback. The DTC does not release the bus during transfer information read, single data transfer, or transfer information writeback. 7.5.11 DTC Priority Level Control to the CPU
The priority of the DTC activation sources over the CPU can be controlled by the CPU priority level specified by bits CPUP2 to CPUP0 in CPUPCR and the DTC priority level specified by bits DTCP2 to DTCP0. For details, see section 5, Interrupt Controller.
Rev.2.00 Jun. 28, 2007 Page 244 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.6
DTC Activation by Interrupt
The procedure for using the DTC with interrupt activation is shown in figure 7.15.
DTC activation by interrupt [1] Clearing the RRS bit in DTCCR to 0 clears the read skip flag of transfer information. Read skip is not performed when the DTC is activated after clearing the RRS bit. When updating transfer information, the RRS bit must be cleared. [2] Set the MRA, MRB, SAR, DAR, CRA, and CRB transfer information in the data area. For details on setting transfer information, see section 7.2, Register Descriptions. For details on location of transfer information, see section 7.4, Location of Transfer Information and DTC Vector Table. [3] Set the start address of the transfer information in the DTC vector table. For details on setting DTC vector table, see section 7.4, Location of Transfer Information and DTC Vector Table. [4] [4] Setting the RRS bit to 1 performs a read skip of second time or later transfer information when the DTC is activated consecutively by the same interrupt source. Setting the RRS bit to 1 is always allowed. However, the value set during transfer will be valid from the next transfer. [5] Set the bit in DTCER corresponding to the DTC activation interrupt source to 1. For the correspondence of interrupts and DTCER, refer to table 7.1. The bit in DTCER may be set to 1 on the second or later transfer. In this case, setting the bit is not needed. [6] Set the enable bits for the interrupt sources to be used as the activation sources to 1. The DTC is activated when an interrupt used as an activation source is generated. For details on the settings of the interrupt enable bits, see the corresponding descriptions of the corresponding module. Clear activation source [7] [7] After the end of one data transfer, the DTC clears the activation source flag or clears the corresponding bit in DTCER and requests an interrupt to the CPU. The operation after transfer depends on the transfer information. For details, see section 7.2, Register Descriptions and figure 7.4.
Clear RRS bit in DTCCR to 0
[1]
Set transfer information (MRA, MRB, SAR, DAR, CRA, CRB)
[2]
Set starts address of transfer information in DTC vector table
[3]
Set RRS bit in DTCCR to 1
Set corresponding bit in DTCER to 1
[5]
Set enable bit of interrupt request for activation source to 1
[6]
Interrupt request generated
DTC activated
Determine clearing method of activation source Clear corresponding bit in DTCER Corresponding bit in DTCER cleared or CPU interrupt requested
Transfer end
Figure 7.15 DTC with Interrupt Activation
Rev.2.00 Jun. 28, 2007 Page 245 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.7
7.7.1
Examples of Use of the DTC
Normal Transfer Mode
An example is shown in which the DTC is used to receive 128 bytes of data via the SCI. 1. Set MRA to fixed source address (SM1 = SM0 = 0), incrementing destination address (DM1 = 1, DM0 = 0), normal transfer mode (MD1 = MD0 = 0), and byte size (Sz1 = Sz0 = 0). The DTS bit can have any value. Set MRB for one data transfer by one interrupt (CHNE = 0, DISEL = 0). Set the RDR address of the SCI in SAR, the start address of the RAM area where the data will be received in DAR, and 128 (H'0080) in CRA. CRB can be set to any value. 2. Set the start address of the transfer information for an RXI interrupt at the DTC vector address. 3. Set the corresponding bit in DTCER to 1. 4. Set the SCI to the appropriate receive mode. Set the RIE bit in SCR to 1 to enable the receive end (RXI) interrupt. Since the generation of a receive error during the SCI reception operation will disable subsequent reception, the CPU should be enabled to accept receive error interrupts. 5. Each time reception of one byte of data ends on the SCI, the RDRF flag in SSR is set to 1, an RXI interrupt is generated, and the DTC is activated. The receive data is transferred from RDR to RAM by the DTC. DAR is incremented and CRA is decremented. The RDRF flag is automatically cleared to 0. 6. When CRA becomes 0 after the 128 data transfers have ended, the RDRF flag is held at 1, the DTCE bit is cleared to 0, and an RXI interrupt request is sent to the CPU. Termination processing should be performed in the interrupt handling routine.
Rev.2.00 Jun. 28, 2007 Page 246 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.7.2
Chain Transfer
An example of DTC chain transfer is shown in which pulse output is performed using the PPG. Chain transfer can be used to perform pulse output data transfer and PPG output trigger cycle updating. Repeat mode transfer to the PPG's NDR is performed in the first half of the chain transfer, and normal mode transfer to the TPU's TGR in the second half. This is because clearing of the activation source and interrupt generation at the end of the specified number of transfers are restricted to the second half of the chain transfer (transfer when CHNE = 0). 1. Perform settings for transfer to the PPG's NDR. Set MRA to source address incrementing (SM1 = 1, SM0 = 0), fixed destination address (DM1 = DM0 = 0), repeat mode (MD1 = 0, MD0 = 1), and word size (Sz1 = 0, Sz0 = 1). Set the source side as a repeat area (DTS = 1). Set MRB to chain transfer mode (CHNE = 1, CHNS = 0, DISEL = 0). Set the data table start address in SAR, the NDRH address in DAR, and the data table size in CRAH and CRAL. CRB can be set to any value. 2. Perform settings for transfer to the TPU's TGR. Set MRA to source address incrementing (SM1 = 1, SM0 = 0), fixed destination address (DM1 = DM0 = 0), normal mode (MD1 = MD0 = 0), and word size (Sz1 = 0, Sz0 = 1). Set the data table start address in SAR, the TGRA address in DAR, and the data table size in CRA. CRB can be set to any value. 3. Locate the TPU transfer information consecutively after the NDR transfer information. 4. Set the start address of the NDR transfer information to the DTC vector address. 5. Set the bit corresponding to the TGIA interrupt in DTCER to 1. 6. Set TGRA as an output compare register (output disabled) with TIOR, and enable the TGIA interrupt with TIER. 7. Set the initial output value in PODR, and the next output value in NDR. Set bits in DDR and NDER for which output is to be performed to 1. Using PCR, select the TPU compare match to be used as the output trigger. 8. Set the CST bit in TSTR to 1, and start the TCNT count operation. 9. Each time a TGRA compare match occurs, the next output value is transferred to NDR and the set value of the next output trigger period is transferred to TGRA. The activation source TGFA flag is cleared. 10. When the specified number of transfers are completed (the TPU transfer CRA value is 0), the TGFA flag is held at 1, the DTCE bit is cleared to 0, and a TGIA interrupt request is sent to the CPU. Termination processing should be performed in the interrupt handling routine.
Rev.2.00 Jun. 28, 2007 Page 247 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.7.3
Chain Transfer when Counter = 0
By executing a second data transfer and performing re-setting of the first data transfer only when the counter value is 0, it is possible to perform 256 or more repeat transfers. An example is shown in which a 128-kbyte input buffer is configured. The input buffer is assumed to have been set to start at lower address H'0000. Figure 7.16 shows the chain transfer when the counter value is 0. 1. For the first transfer, set the normal transfer mode for input data. Set the fixed transfer source address, CRA = H'0000 (65,536 times), CHNE = 1, CHNS = 1, and DISEL = 0. 2. Prepare the upper 8-bit addresses of the start addresses for 65,536-transfer units for the first data transfer in a separate area (in ROM, etc.). For example, if the input buffer is configured at addresses H'200000 to H'21FFFF, prepare H'21 and H'20. 3. For the second transfer, set repeat transfer mode (with the source side as the repeat area) for resetting the transfer destination address for the first data transfer. Use the upper eight bits of DAR in the first transfer information area as the transfer destination. Set CHNE = DISEL = 0. If the above input buffer is specified as H'200000 to H'21FFFF, set the transfer counter to 2. 4. Execute the first data transfer 65536 times by means of interrupts. When the transfer counter for the first data transfer reaches 0, the second data transfer is started. Set the upper eight bits of the transfer source address for the first data transfer to H'21. The lower 16 bits of the transfer destination address of the first data transfer and the transfer counter are H'0000. 5. Next, execute the first data transfer the 65536 times specified for the first data transfer by means of interrupts. When the transfer counter for the first data transfer reaches 0, the second data transfer is started. Set the upper eight bits of the transfer source address for the first data transfer to H'20. The lower 16 bits of the transfer destination address of the first data transfer and the transfer counter are H'0000. 6. Steps 4 and 5 are repeated endlessly. As repeat mode is specified for the second data transfer, no interrupt request is sent to the CPU.
Rev.2.00 Jun. 28, 2007 Page 248 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
Input circuit
Transfer information located on the on-chip memory Input buffer
1st data transfer information 2nd data transfer information
Chain transfer (counter = 0)
Upper 8 bits of DAR
Figure 7.16 Chain Transfer when Counter = 0
7.8
Interrupt Sources
An interrupt request is issued to the CPU when the DTC finishes the specified number of data transfers or a data transfer for which the DISEL bit was set to 1. In the case of interrupt activation, the interrupt set as the activation source is generated. These interrupts to the CPU are subject to CPU mask level and priority level control in the interrupt controller.
7.9
7.9.1
Usage Notes
Module Stop State Setting
Operation of the DTC can be disabled or enabled using the module stop control register. The initial setting is for operation of the DTC to be enabled. Register access is disabled by setting module stop state. Module stop state cannot be set while the DTC is activated. For details, see section 18, Power-Down States.
Rev.2.00 Jun. 28, 2007 Page 249 of 666 REJ09B0311-0200
Section 7 Data Transfer Controller (DTC)
7.9.2
On-Chip RAM
Transfer information can be located in on-chip RAM. In this case, the RAME bit in SYSCR must not be cleared to 0. 7.9.3 DTCE Bit Setting
For DTCE bit setting, use bit manipulation instructions such as BSET and BCLR. If all interrupts are disabled, multiple activation sources can be set at one time (only at the initial setting) by writing data after executing a dummy read on the relevant register. 7.9.4 Chain Transfer
When chain transfer is used, clearing of the activation source or DTCER is performed when the last of the chain of data transfers is executed. SCI and A/D converter interrupt/activation sources, on the other hand, are cleared when the DTC reads or writes to the relevant register. Therefore, when the DTC is activated by an interrupt or activation source, if a read/write of the relevant register is not included in the last chained data transfer, the interrupt or activation source will be retained. 7.9.5 Transfer Information Start Address, Source Address, and Destination Address
The transfer information start address to be specified in the vector table should be address 4n. If an address other than address 4n is specified, the lower 2 bits of the address are regarded as 0s. The source and destination addresses specified in SAR and DAR, respectively, will be transferred in the divided bus cycles depending on the address and data size. 7.9.6 Endian
The DTC supports the big-endian and little-endian format. However, use the same endian format for writing and reading the transfer information.
Rev.2.00 Jun. 28, 2007 Page 250 of 666 REJ09B0311-0200
Section 8 I/O Ports
Section 8 I/O Ports
Table 8.1 summarizes the port functions. The pins of each port also have other functions such as input/output pins of on-chip peripheral modules or external interrupt input pins. Each I/O port includes a data direction register (DDR) that controls input/output, a data register (DR) that stores output data, a port register (PORT) used to read the pin states, and an input buffer control register (ICR) that controls input buffer on/off. Port 5 does not have a DR or a DDR register. Ports D to F, H, and I have internal input pull-up MOSs and a pull-up MOS control register (PCR) that controls the on/off state of the input pull-up MOSs. Ports 2 and F include an open-drain control register (ODR) that controls on/off of the output buffer PMOSs. All of the I/O ports can drive a single TTL load and capacitive loads up to 30 pF. All of the I/O ports can drive Darlington transistors when functioning as output ports. Ports 2 and 3 are Schmitt-trigger inputs. Schmitt-trigger inputs for other ports are enabled when used as the IRQ, TPU, or TMR inputs. Table 8.1 Port Functions
Function SchmittTrigger 1 Input* IRQ7-A, TCLKD-B IRQ6-A, TCLKC-B IRQ5-A, TCLKB-B IRQ4-A, TCLKA-B IRQ3-A IRQ2-A IRQ1-A IRQ0-A Input Pull-up MOS Function OpenDrain Output Function
Port
Description
Bit
I/O P17 P16 P15 P14 P13 P12/SCK2 P11 P10
Input IRQ7-A/ TCLKD-B IRQ6-A/ TCLKC-B IRQ5-A/ TCLKB-B IRQ4-A/ TCLKA-B ADTRG0/ IRQ3-A IRQ2-A RxD2/ IRQ1-A IRQ0-A
Output TxD2
Port 1 General I/O port 7 also functioning as interrupt inputs, 6 SCI I/Os, A/D converter inputs, 5 and TPU inputs 4 3 2 1 0
Rev.2.00 Jun. 28, 2007 Page 251 of 666 REJ09B0311-0200
Section 8 I/O Ports
Function SchmittTrigger 1 Input * All input functions
Port
Description
Bit
I/O P27/ TIOCB5 P26/ TIOCA5 P25/ TIOCA4 P24/ TIOCB4/ SCK1 P23/ TIOCD3 P22/ TIOCC3 P21/ TIOCA3
Input TIOCA5
Output PO7
Input Pull-up MOS Function
OpenDrain Output Function O
Port 2 General I/O port 7 also functioning as interrupt inputs, 6 PPG outputs, TPU I/Os, TMR I/Os, 5 and SCI I/Os
TMCI1/ RxD1 TIOCA4/ TMRI1
PO6/TMO1/ All input TxD1 functions PO5 P25, TIOCA4, TMCI1 P24, TIOCB4, TIOCA4, TMRI1 All input functions
4
PO4
3 2 1
IRQ11-A/ TIOCC3 IRQ10-A TMCI0/ RxD0/ IRQ9-A TIOCA3/ TMRI0/ IRQ8-A
PO3
PO2/TMO0/ All input TxD0/ functions PO1 P21, IRQ9-A, TIOCA3, TMCI0 P20, IRQ8-A, TIOCB3, TIOCA3, TMRI0
0
P20/ TIOCB3/ SCK0
PO0
Rev.2.00 Jun. 28, 2007 Page 252 of 666 REJ09B0311-0200
Section 8 I/O Ports
Function SchmittTrigger 1 Input* All input functions All input functions All input functions All input functions All input functions All input functions All input functions All input functions IRQ7-B IRQ6-B IRQ5-B IRQ4-B IRQ3-B IRQ2-B IRQ1-B IRQ0-B
Port
Description
Bit 7 6 5 4 3 2 1 0
I/O P37/ TIOCB2 P36/ TIOCA2 P35/ TIOCB1 P34/ TIOCA1 P33/ TIOCD0 P32/ TIOCC0 P31/ TIOCB0 P30/ TIOCA0
Input TIOCA2/ TCLKD-A TIOCA1/ TCLKC-A TIOCC0/ TCLKB-A TCLKA-A TIOCA0
Output PO15 PO14 PO13 PO12 PO11 PO10 PO9 PO8 DA1 DA0
Input Pull-up MOS Function
OpenDrain Output Function
Port 3 General I/O port also functioning as PPG outputs and TPU I/Os.
P57/AN7 IRQ7-B P56/AN6 IRQ6-B P55/AN5 IRQ5-B P54/AN4 IRQ4-B P53/AN3 IRQ3-B P52/AN2 IRQ2-B P51/AN1 IRQ1-B P50/AN0 IRQ0-B
Port 5 General input port 7 also functioning as A/D converter 6 inputs and D/A converter outputs 5 4 3 2 1 0
Rev.2.00 Jun. 28, 2007 Page 253 of 666 REJ09B0311-0200
Section 8 I/O Ports
Function SchmittTrigger 1 Input* TMCI3 TMRI3/ IRQ11-B IRQ10-B TMCI2/ IRQ9-B TMRI2/ IRQ8-B
Port
Description
Bit 7 6 5 4 3 2 1
I/O P65 P64 P63 P62/SCK4 P61
Input TMCI3 TMRI3/ IRQ11-B IRQ10-B TMCI2/ RxD4/ IRQ9-B TMRI2/ IRQ8-B PA7 BREQ/ WAIT
Output TMO3 TMO2
Input Pull-up MOS Function
OpenDrain Output Function
Port 6 General I/O port also functioning as TMR I/Os, SCI I/Os, and interrupt inputs
0 Port A General I/O port also functioning as system clock output and bus control I/Os 7 6 5 4 3 2 1 0
P60 PA6 PA4 PA2 PA1 PA0
TxD4 B AS/AH/ BS-B RD LHWR/LUB LLWR/LLB BACK/ (RD/WR) BREQO/ BS-A
Rev.2.00 Jun. 28, 2007 Page 254 of 666 REJ09B0311-0200
Section 8 I/O Ports
Function SchmittTrigger 1 Input*
Port
Description
Bit 7 6 5 4 3 2 1
I/O PB3 PB2 PB1
Input
Output CS3/ CS7-A CS2-A/ CS6-A CS1/ CS2-B/ CS5-A/ CS6-B/ CS7-B CS0/CS4-A/ CS5-B A7 A6 A5 A4 A3 A2 A1 A0 A15 A14 A13 A12 A11 A10 A9 A8
Input Pull-up MOS Function
OpenDrain Output Function
Port B General I/O port also functioning as bus control outputs
0 Port D General I/O port also functioning as address outputs 7 6 5 4 3 2 1 0 Port E General I/O port also functioning as address outputs 7 6 5 4 3 2 1 0
PB0

O
O
Rev.2.00 Jun. 28, 2007 Page 255 of 666 REJ09B0311-0200
Section 8 I/O Ports
Function SchmittTrigger 1 Input*
Port
Description
Bit 7
I/O PF7
Input
Output
Input Pull-up MOS Function O
OpenDrain Output Function O
Port F General I/O port also functioning as address outputs
A23/CS4-C/ CS5-C/ CS6-C/ CS7-C A22/CS6-D A21/CS5-D A20 A19 A18 A17 A16
6 5 4 3 2 1 0 Port H General I/O port also functioning as bi-directional data bus 7 6 5 4 3 2 1 0 Port I General I/O port also functioning as bi-directional data bus 7 6 5 4 3 2 1 0
PF6 PF5 D7*
2

2
O
D6* D5*
2
2
D4* D3* D2* D1* D0*
2
2
2
2
2
PI7/D15*

O
PI6/D14* PI5/D13* PI4/D12* PI3/D11* PI2/D10* PI1/D9* PI0/D8*
2
2
2
2
2
2
2
Notes: 1. Pins without Schmitt-trigger input buffer have CMOS input buffer. 2. Addresses are also output when accessing to the address/data multiplexed I/O space.
Rev.2.00 Jun. 28, 2007 Page 256 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.1
Register Descriptions
Table 8.2 lists each port registers. Table 8.2 Register Configuration in Each Port
Number of Pins 8 8 8 8
1
Registers DDR O O O O O O O O O O O DR O O O O O O O O O O O PORT O O O O O O O O O O O O ICR O O O O O O O O O O O O PCR O O O O O ODR O O
Port Port 1 Port 2 Port 3 Port 5 Port 6* Port A Port B* Port D Port E Port F Port H Port I
2
6 8 4 8 8 8 8 8
[Legend] O: Register exists : No register exists Notes: 1. The lower six bits are valid and the upper two bits are reserved. The write value should always be the initial value. 2. The lower four bits are valid and the upper four bits are reserved. The write value should always be the initial value.
Rev.2.00 Jun. 28, 2007 Page 257 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.1.1
Data Direction Register (PnDDR) (n = 1 to 3, 6, A, B, D to F, H, and I)
DDR is an 8-bit write-only register that specifies the port input or output for each bit. A read from the DDR is invalid and DDR is always read as an undefined value. When the general I/O port function is selected, the corresponding pin functions as an output port by setting the corresponding DDR bit to 1; the corresponding pin functions as an input port by clearing the corresponding DDR bit to 0. The initial DDR values are shown in table 8.3.
Bit Bit Name Initial Value R/W Note: 7 Pn7DDR 0 W 6 Pn6DDR 0 W 5 Pn5DDR 0 W 4 Pn4DDR 0 W 3 Pn3DDR 0 W 2 Pn2DDR 0 W 1 Pn1DDR 0 W 0 Pn0DDR 0 W
The lower six bits are valid and the upper two bits are reserved for port 6 registers. The lower four bits are valid and the upper four bits are reserved for port B registers.
Table 8.3
Startup Mode and Initial Value
Startup Mode
Port Port A Other ports
External Extended Mode H'80 H'00
Rev.2.00 Jun. 28, 2007 Page 258 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.1.2
Data Register (PnDR) (n = 1 to 3, 6, A, B, D to F, H, and I)
DR is an 8-bit readable/writable register that stores the output data of the pins to be used as the general output port. The initial value of DR is H'00.
Bit Bit Name Initial Value R/W Note: 7 Pn7DR 0 R/W 6 Pn6DR 0 R/W 5 Pn5DR 0 R/W 4 Pn4DR 0 R/W 3 Pn3DR 0 R/W 2 Pn2DR 0 R/W 1 Pn1DR 0 R/W 0 Pn0DR 0 R/W
The lower six bits are valid and the upper two bits are reserved for port 6 registers. The lower four bits are valid and the upper four bits are reserved for port B registers.
8.1.3
Port Register (PORTn) (n = 1 to 3, 5, 6, A, B, D to F, H, and I)
PORT is an 8-bit read-only register that reflects the port pin status. A write to PORT is invalid. When PORT is read, the DR bits that correspond to the respective DDR bits set to 1 are read and the status of each pin whose corresponding DDR bit is cleared to 0 is also read regardless of the ICR value. The initial value of PORT is undefined and is determined based on the port pin status.
Bit Bit Name Initial Value R/W Note: 7 Pn7 Undefined R 6 Pn6 Undefined R 5 Pn5 Undefined R 4 Pn4 Undefined R 3 Pn3 Undefined R 2 Pn2 Undefined R 1 Pn1 Undefined R 0 Pn0 Undefined R
The lower six bits are valid and the upper two bits are reserved for port 6 registers. The lower four bits are valid and the upper four bits are reserved for port B registers.
Rev.2.00 Jun. 28, 2007 Page 259 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.1.4
Input Buffer Control Register (PnICR) (n = 1 to 3, 5, 6, A, B, D to F, H, and I)
ICR is an 8-bit readable/writable register that controls the port input buffers. For bits in ICR set to 1, the input buffers of the corresponding pins are valid. For bits in ICR cleared to 0, the input buffers of the corresponding pins are invalid and the input signals are fixed high. When the pin functions as an input for the peripheral modules, the corresponding bits should be set to 1. The initial value should be written to a bit whose corresponding pin is not used as an input or is used as an analog input/output pin. If the bits in ICR have been cleared to 0, the pin state is not reflected to the peripheral modules. When PORT is read, the pin status is always read regardless of the ICR value. If ICR is modified, an internal edge may occur depending on the pin status. Accordingly, ICR should be modified when the corresponding input pins are not used. For example, in IRQ input, modify ICR while the corresponding interrupt is disabled, clear the IRQF flag in ISR of the interrupt controller to 0, and then enable the corresponding interrupt. If an edge occurs after the ICR setting, the edge should be cancelled. The initial value of ICR is H'00.
Bit Bit Name Initial Value R/W Note: 7 Pn7ICR 0 R/W 6 Pn6ICR 0 R/W 5 Pn5ICR 0 R/W 4 Pn4ICR 0 R/W 3 Pn3ICR 0 R/W 2 Pn2ICR 0 R/W 1 Pn1ICR 0 R/W 0 Pn0ICR 0 R/W
The lower six bits are valid and the upper two bits are reserved for port 6 registers. The lower four bits are valid and the upper four bits are reserved for port B registers.
Rev.2.00 Jun. 28, 2007 Page 260 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.1.5
Pull-Up MOS Control Register (PnPCR) (n = D to F, H, and I)
PCR is an 8-bit readable/writable register that controls on/off of the port input pull-up MOS. If a bit in PCR is set to 1 while the pin is in input state, the input pull-up MOS corresponding to the bit in PCR is turned on. Table 8.4 shows the input pull-up MOS status. The initial value of PCR is H'00.
Bit Bit Name Initial Value R/W 7 Pn7PCR 0 R/W 6 Pn6PCR 0 R/W 5 Pn5PCR 0 R/W 4 Pn4PCR 0 R/W 3 Pn3PCR 0 R/W 2 Pn2PCR 0 R/W 1 Pn1PCR 0 R/W 0 Pn0PCR 0 R/W
Table 8.4
Port Port D
Input Pull-Up MOS State
Pin State Address output Port output Port input OFF OFF OFF OFF OFF OFF OFF OFF OFF OFF OFF OFF OFF ON/OFF ON/OFF ON/OFF ON/OFF Reset Hardware Standby Mode Software Standby Mode OFF OFF ON/OFF Other Operation
Port E
Address output Port output Port input
Port F
Address output Peripheral module output Port input
Port H
Data input/output Port output Port input
Port I
Data input/output Port output Port input
[Legend] OFF: ON/OFF: The input pull-up MOS is always off. If PCR is set to 1, the input pull-up MOS is on; if PCR is cleared to 0, the input pull-up MOS is off.
Rev.2.00 Jun. 28, 2007 Page 261 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.1.6
Open-Drain Control Register (PnODR) (n = 2 and F)
ODR is an 8-bit readable/writable register that selects the open-drain output function. If a bit in ODR is set to 1, the pin corresponding to that bit in ODR functions as an NMOS opendrain output. If a bit in ODR is cleared to 0, the pin corresponding to that bit in ODR functions as a CMOS output. The initial value of ODR is H'00.
Bit Bit Name Initial Value R/W 7 Pn7ODR 0 R/W 6 Pn6ODR 0 R/W 5 Pn5ODR 0 R/W 4 Pn4ODR 0 R/W 3 Pn3ODR 0 R/W 2 Pn2ODR 0 R/W 1 Pn1ODR 0 R/W 0 Pn0ODR 0 R/W
8.2
Output Buffer Control
This section describes the output priority of each pin. The name of each peripheral module pin is followed by "_OE". This (for example: MIOCA4_OE) indicates whether the output of the corresponding function is valid (1) or if another setting is specified (0). Table 8.5 lists each port output signal's valid setting. For details on the corresponding output signals, see the register description of each peripheral module. If the name of each peripheral module pin is followed by A or B, the pin function can be modified by the port function control register (PFCR). For details, see section 8.3, Port Function Controller. 8.2.1 (1) Port 1 P17/IRQ7-A/TCLKD-B
The pin function is switched as shown below according to the P17DDR bit setting.
Setting I/O Port Module Name I/O port Pin Function P17 output P17DDR 1
P17 input (initial setting) 0
Rev.2.00 Jun. 28, 2007 Page 262 of 666 REJ09B0311-0200
Section 8 I/O Ports
(2)
P16/IRQ6-A/TCLKC-B
The pin function is switched as shown below according to the P16DDR bit setting.
Setting I/O Port Module Name I/O port Pin Function P16 output P16DDR 1
P16 input (initial setting) 0
(3)
P15/IRQ5-A/TCLKB-B
The pin function is switched as shown below according to the P15DDR bit setting.
Setting I/O Port Module Name I/O port Pin Function P15 output P15DDR 1
P15 input (initial setting) 0
(4)
P14/IRQ4-A/TCLKA-B
The pin function is switched as shown below according to the P14DDR bit setting.
Setting I/O Port Module Name I/O port Pin Function P14 output P14DDR 1
P14 input (initial setting) 0
Rev.2.00 Jun. 28, 2007 Page 263 of 666 REJ09B0311-0200
Section 8 I/O Ports
(5)
P13/ADTRG0/IRQ3-A
The pin function is switched as shown below according to the P13DDR bit setting.
Setting I/O Port Module Name I/O port Pin Function P13 output P13DDR 1
P13 input (initial setting) 0
(6)
P12/SCK2/IRQ2-A
The pin function is switched as shown below according to the combination of the SCI register setting and P12DDR bit setting.
Setting SCI Module Name SCI I/O port Pin Function SCK2 output P12 output SCK2_OE 1 0 I/O Port P12DDR 1 0
P12 input (initial setting) 0
(7)
P11/RxD2/IRQ1-A
The pin function is switched as shown below according to the P11DDR bit setting.
Setting I/O Port Module Name I/O port Pin Function P11 output P11DDR 1
P11 input (initial setting) 0
Rev.2.00 Jun. 28, 2007 Page 264 of 666 REJ09B0311-0200
Section 8 I/O Ports
(8)
P10/TxD2/IRQ0-A
The pin function is switched as shown below according to the combination of the SCI register setting and P10DDR bit setting.
Setting SCI Module Name SCI I/O port Pin Function TxD2 output P10 output P10 input (initial setting) TxD2_OE 1 0 0 I/O Port P10DDR 1 0
8.2.2 (1)
Port 2 P27/PO7/TIOCA5/TIOCB5
The pin function is switched as shown below according to the combination of the TPU and PPG register settings and P27DDR bit setting.
Setting TPU Module Name TPU PPG I/O port Pin Function TIOCB5 output PO7 output P27 output P27 input (initial setting) TIOCB5_OE 1 0 0 0 PPG PO7_OE 1 0 0 I/O Port P27DDR 1 0
Rev.2.00 Jun. 28, 2007 Page 265 of 666 REJ09B0311-0200
Section 8 I/O Ports
(2)
P26/PO6/TIOCA5/TMO1/TxD1
The pin function is switched as shown below according to the combination of the TPU, TMR, SCI, and PPG register settings and P26DDR bit setting.
Setting TPU Module Name Pin Function TPU TMR SCI PPG I/O port TMR 1 0 0 0 0 SCI TxD1_OE 1 0 0 0 PPG PO6_OE 1 0 0 I/O Port P26DDR 1 0
TIOCA5_OE TMO1_OE
TIOCA5 output 1 TMO1 output TxD1 output PO6 output P26 output 0 0 0 0
P26 input 0 (initial setting)
(3)
P25/PO5/TIOCA4/TMCI1/RxD1
The pin function is switched as shown below according to the combination of the TPU and PPG register settings and P25DDR bit setting.
Setting TPU Module Name TPU PPG I/O port Pin Function TIOCA4 output PO5 output P25 output P25 input (initial setting) TIOCA4_OE 1 0 0 0 PPG PO5_OE 1 0 0 I/O Port P25DDR 1 0
Rev.2.00 Jun. 28, 2007 Page 266 of 666 REJ09B0311-0200
Section 8 I/O Ports
(4)
P24/PO4/TIOCA4/TIOCB4/TMRI1/SCK1
The pin function is switched as shown below according to the combination of the TPU, SCI, and PPG register settings and P24DDR bit setting.
Setting TPU Module Name Pin Function TPU SCI PPG I/O port TIOCB4 output SCK1 output PO4 output P24 output P24 input (initial setting) TIOCB4_OE 1 0 0 0 0 SCI SCK1_OE 1 0 0 0 PPG PO4_OE 1 0 0 I/O Port P24DDR 1 0
(5)
P23/PO3/TIOCC3/TIOCD3/IRQ11-A
The pin function is switched as shown below according to the combination of the TPU and PPG register settings and P23DDR bit setting.
Setting TPU Module Name TPU PPG I/O port Pin Function TIOCD3 output PO3 output P23 output P23 input (initial setting) TIOCD3_OE 1 0 0 0 PPG PO3_OE 1 0 0 I/O Port P23DDR 1 0
Rev.2.00 Jun. 28, 2007 Page 267 of 666 REJ09B0311-0200
Section 8 I/O Ports
(6)
P22 /PO2/TIOCC3/TMO0/TxD0/IRQ10-A
The pin function is switched as shown below according to the combination of the TPU, TMR, SCI, and PPG register settings and P22DDR bit setting.
Setting TPU Module Name Pin Function TPU TMR SCI PPG I/O port TIOCC3 output TMO0 output TxD0 output PO2 output P22 output TMR 1 0 0 0 0 SCI TxD0_OE 1 0 0 0 PPG PO2_OE 1 0 0 I/O Port P22DDR 1 0
TIOCC3_OE TMO0_OE 1 0 0 0 0
P22 input 0 (initial setting)
(7)
P21/PO1/TIOCA3/TMCI0/RxD0/IRQ9-A
The pin function is switched as shown below according to the combination of the TPU and PPG register settings and P21DDR bit setting.
Setting TPU Module Name TPU PPG I/O port Pin Function TIOCA3 output PO1 output P21 output P21 input (initial setting) TIOCA3_OE 1 0 0 0 PPG PO1_OE 1 0 0 I/O Port P21DDR 1 0
Rev.2.00 Jun. 28, 2007 Page 268 of 666 REJ09B0311-0200
Section 8 I/O Ports
(8)
P20/PO0/TIOCA3/TIOCB3/TMRI0/SCK0/IRQ8-A
The pin function is switched as shown below according to the combination of the TPU, SCI, and PPG register settings and P20DDR bit setting.
Setting TPU Module Name Pin Function TPU PPG SCI I/O port TIOCB3 output PO0 output SCK0 output P20 output P20 input (initial setting) TIOCB3_OE 1 0 0 0 0 SCI SCK0_OE 1 0 0 0 PPG PO0_OE 1 0 0 I/O Port P20DDR 1 0
8.2.3 (1)
Port 3 P37/PO15/TIOCA2/TIOCB2/TCLKD-A
The pin function is switched as shown below according to the combination of the TPU and PPG register settings and P37DDR bit setting.
Setting TPU Module Name TPU PPG I/O port Pin Function TIOCB2 output PO15 output P37 output P37 input (initial setting) TIOCB2_OE 1 0 0 0 PPG PO15_OE 1 0 0 I/O Port P37DDR 1 0
Rev.2.00 Jun. 28, 2007 Page 269 of 666 REJ09B0311-0200
Section 8 I/O Ports
(2)
P36/PO14/TIOCA2
The pin function is switched as shown below according to the combination of the TPU and PPG register settings and P36DDR bit setting.
Setting TPU Module Name TPU PPG I/O port Pin Function TIOCA2 output PO14 output P36 output P36 input (initial setting) TIOCA2_OE 1 0 0 0 PPG PO14_OE 1 0 0 I/O Port P36DDR 1 0
(3)
P35/PO13/TIOCA1/TIOCB1/TCLKC-A
The pin function is switched as shown below according to the combination of the TPU and PPG register settings and P35DDR bit setting.
Setting TPU Module Name TPU PPG I/O port Pin Function TIOCB1 output PO13 output P35 output P35 input (initial setting) TIOCB1_OE 1 0 0 0 PPG PO13_OE 1 0 0 I/O Port P35DDR 1 0
Rev.2.00 Jun. 28, 2007 Page 270 of 666 REJ09B0311-0200
Section 8 I/O Ports
(4)
P34/PO12/TIOCA1
The pin function is switched as shown below according to the combination of the TPU and PPG register settings and P34DDR bit setting.
Setting TPU Module Name TPU PPG I/O port Pin Function TIOCA1 output PO12 output P34 output P34 input (initial setting) TIOCA1_OE 1 0 0 0 PPG PO12_OE 1 0 0 I/O Port P34DDR 1 0
(5)
P33/PO11/TIOCC0/TIOCD0/TCLKB-A
The pin function is switched as shown below according to the combination of the TPU and PPG register settings and P33DDR bit setting.
Setting TPU Module Name TPU PPG I/O port Pin Function TIOCD0 output PO11 output P33 output P33 input (initial setting) TIOCD0_OE 1 0 0 0 PPG PO11_OE 1 0 0 I/O Port P33DDR 1 0
Rev.2.00 Jun. 28, 2007 Page 271 of 666 REJ09B0311-0200
Section 8 I/O Ports
(6)
P32/PO10/TIOCC0/TCLKA-A
The pin function is switched as shown below according to the combination of the TPU and PPG register settings and P32DDR bit setting.
Setting TPU Module Name TPU PPG I/O port Pin Function TIOCC0 output PO10 output P32 output P32 input (initial setting) TIOCC0_OE 1 0 0 0 PPG PO10_OE 1 0 0 I/O Port P32DDR 1 0
(7)
P31/PO9/TIOCA0/TIOCB0
The pin function is switched as shown below according to the combination of the TPU and PPG register settings and P31DDR bit setting.
Setting TPU Module Name TPU PPG I/O port Pin Function TIOCB0 output PO9 output P31 output P31 input (initial setting) TIOCB0_OE 1 0 0 0 PPG PO9_OE 1 0 0 I/O Port P31DDR 1 0
Rev.2.00 Jun. 28, 2007 Page 272 of 666 REJ09B0311-0200
Section 8 I/O Ports
(8)
P30/PO8/TIOCA0
The pin function is switched as shown below according to the combination of the TPU and PPG register settings and P30DDR bit setting.
Setting TPU Module Name TPU PPG I/O port Pin Function TIOCA0 output PO8 output P30 output P30 input (initial setting) TIOCA0_OE 1 0 0 0 PPG PO8_OE 1 0 0 I/O Port P30DDR 1 0
8.2.4
Port 5
P57/AN7/DA1/IRQ7-B:
Module Name D/A converter Pin Function DA1 output
P56/AN6/DA0/IRQ6-B:
Module Name D/A converter Pin Function DA0 output
Rev.2.00 Jun. 28, 2007 Page 273 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.2.5 (1)
Port 6 P65/TMO3
The pin function is switched as shown below according to the combination of the TMR register setting and P65DDR bit setting.
Setting TMR Module Name TMR I/O port Pin Function TMO3 output P65 output P65 input (initial setting) TMO3_OE 1 0 0 I/O Port P65DDR 1 0
(2)
P64/TMCI3
The pin function is switched as shown below according to the P64DDR bit setting.
Setting I/O Port Module Name I/O port Pin Function P64 output P64 input (initial setting) P64DDR 1 0
(3)
P63/TMRI3/IRQ11-B
The pin function is switched as shown below according to the P63DDR bit setting.
Setting I/O Port Module Name I/O port Pin Function P63 output P63 input (initial setting) P63DDR 1 0
Rev.2.00 Jun. 28, 2007 Page 274 of 666 REJ09B0311-0200
Section 8 I/O Ports
(4)
P62/TMO2/SCK4/IRQ10-B
The pin function is switched as shown below according to the combination of the TMR and SCI register settings and P62DDR bit setting.
Setting TMR Module Name TMR SCI I/O port Pin Function TMO2 output SCK4 output P62 output P62 input (initial setting) TMO2_OE 1 0 0 0 SCI SCK4_OE 1 0 0 I/O Port P62DDR 1 0
(5)
P61/TMCI2/RxD4/IRQ9-B
The pin function is switched as shown below according to the P61DDR bit setting.
Setting I/O Port Module Name I/O port Pin Function P61 output P61DDR 1
P61 input (initial 0 setting)
(6)
P60/TMRI2/TxD4/IRQ8-B
The pin function is switched as shown below according to the combination of the SCI register setting and P60DDR bit setting.
Setting SCI Module Name SCI I/O port Pin Function TxD4 output P60 output P60 input (initial setting) TxD4_OE 1 0 0 I/O Port P60DDR 1 0
Rev.2.00 Jun. 28, 2007 Page 275 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.2.6 (1)
Port A PA7/B
The pin function is switched as shown below according to the PA7DDR bit setting.
Setting I/O Port Module Name I/O port Note: * Pin Function B output* (initial setting) PA7 input PA7DDR 1 0
The type of to be output switches according to the POSEL1 bit in SCKCR. For details, see section 17.1.1, System Clock Control Register (SCKCR).
(2)
PA6/AS/AH/BS-B
The pin function is switched as shown below according to the combination of bus controller register, port function control register (PFCR), and the PA6DDR bit settings.
Setting Bus Controller Module Name Bus controller Pin Function AH output BS-B output AS output (initial setting) I/O port PA6 output PA6 input AH_OE 1 0 0 0 0 BS-B_OE 1 0 0 0 AS_OE 1 0 0 I/O Port PA6DDR 1 0
Rev.2.00 Jun. 28, 2007 Page 276 of 666 REJ09B0311-0200
Section 8 I/O Ports
(3)
PA5/RD
The pin function is always RD output.
Setting MCU Operating Mode Module Name Bus controller Pin Function RD output (initial setting) EXPE 1 I/O Port PA5DDR
(4)
PA4/LHWR/LUB
The pin function is switched as shown below according to the combination of bus controller register, port function control register (PFCR), and the PA4DDR bit settings.
Setting Bus Controller Module Name Bus controller Pin Function LUB output LHWR output (initial setting) I/O port Note: PA4 output PA4 input LUB_OE* 1 0 0 LHWR_OE* 1 0 0 I/O Port PA4DDR 1 0
*. When the byte control SRAM space is accessed while the byte control SRAM space is specified or while LHWROE =1, this pin functions as the LUB output; otherwise, the LHWR output.
Rev.2.00 Jun. 28, 2007 Page 277 of 666 REJ09B0311-0200
Section 8 I/O Ports
(5)
PA3/LLWR/LLB
The pin function is switched as shown below according to the combination of bus controller register, and the PA3DDR bit settings.
Setting Bus Controller Module Name Bus controller Pin Function LLB output LLWR output (initial setting) Note: * LLB_OE* 1 LLWR_OE* 1 I/O Port PA3DDR
If the byte control SRAM space is accessed, this pin functions as the LLB output; otherwise, the LLWR.
(6)
PA2/BREQ/WAIT
The pin function is switched as shown below according to the combination of operating mode, EXPE bit, bus controller register, and the PA2DDR bit settings.
Setting Bus Controller Module Name Bus controller Pin Function BREQ input WAIT input I/O port PA2 output PA2 input (initial setting) BCR_BRLE 1 0 0 0 BCR_WAITE 1 0 0 I/O Port PA2DDR 1 0
Rev.2.00 Jun. 28, 2007 Page 278 of 666 REJ09B0311-0200
Section 8 I/O Ports
(7)
PA1/BACK/(RD/WR)
The pin function is switched as shown below according to the combination of bus controller register, port function control register (PFCR), and the PA1DDR bit settings.
Setting Bus Controller Byte control SRAM Selection 1 0 0 0 I/O Port
Module Name Bus controller
Pin Function BACK output RD/WR output
BACK_OE 1 0 0
(RD/WR)_OE 1 0 0
PA1DDR 1 0
I/O port
PA1 output PA1 input (initial setting)
0 0
(8)
PA0/BREQO/BS-A
The pin function is switched as shown below according to the combination of bus controller register, port function control register (PFCR), and the PA0DDR bit settings.
Setting I/O Port Module Name Bus controller Pin Function BS-A output BREQO output I/O port PA0 output PA0 input (initial setting) BS-A_OE 1 0 0 0 Bus Controller BREQ_OE 1 0 0 I/O Port PA0DDR 1 0
Rev.2.00 Jun. 28, 2007 Page 279 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.2.7 (1)
Port B PB3/CS3/CS7-A
The pin function is switched as shown below according to the combination of port function control register (PFCR) and the PB3DDR bit settings.
Setting I/O Port Module Name Bus controller Pin Function CS3 output CS7-A output I/O port PB3 output PB3 input (initial setting) CS3_OE 1 0 0 CS7A_OE 1 0 0 PB3DDR 1 0
(2)
PB2/CS2-A/CS6-A
The pin function is switched as shown below according to the combination of port function control register (PFCR) and the PB2DDR bit settings.
Setting I/O Port Module Name Bus controller Pin Function CS2-A output CS6-A output I/O port PB2 output PB2 input (initial setting) CS2A_OE 1 0 0 CS6A_OE 1 0 0 PB2DDR 1 0
Rev.2.00 Jun. 28, 2007 Page 280 of 666 REJ09B0311-0200
Section 8 I/O Ports
(3)
PB1/CS1/CS2-B/CS5-A/CS6-B/CS7-B
The pin function is switched as shown below according to the combination of port function control register (PFCR) and the PB1DDR bit settings.
Setting I/O Port Module Name Bus controller Pin Function CS1 output CS2-B output CS5-A output CS6-B output CS7-B output I/O port PB1 output PB1 input (initial setting)
CS1_OE 1 0 0 CS2B_OE CS5A_OE CS6B_OE CS7B_OE PB1DDR 1 0 0 1 0 0 1 0 0 1 0 0 1 0
(4)
PB0/CS0/CS4-A/CS5-B
The pin function is switched as shown below according to the combination of port function control register (PFCR) and the PB0DDR bit settings.
Setting I/O Port Module Name Bus controller Pin Function CS0 output (initial setting) CS4-A output CS5-B output I/O port PB0 output PB0 input CS0_OE 1 0 0 CS4-A_OE 1 0 0 CS5B_OE 1 0 0 PB0DDR 1 0
Rev.2.00 Jun. 28, 2007 Page 281 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.2.8 (1)
Port D PD7/A7, PD6/A6, PD5/A5, PD4/A4, PD3/A3, PD2/A2, PD1/A1, PD0/A0
The pin function is always address output.
Setting I/O Port Module Name Bus controller [Legend] n = 0 to 7 Pin Function PDnDDR Address output
8.2.9 (1)
Port E PE7/A15, PE6/A14, PE5/A13, PE4/A12, PE3/A11, PE2/A10, PE1/A9, PE0/A8
The pin function is always address output.
Setting I/O Port Module Name Bus controller [Legend] n = 0 to 7 Pin Function PEnDDR Address output 1
Rev.2.00 Jun. 28, 2007 Page 282 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.2.10 (1)
Port F
PF7/A23/CS4-C/CS5-C/CS6-C/CS7-C
The pin function is switched as shown below according to the combination of port function control register (PFCR) and the PF7DDR bit settings.
Setting I/O Port Module Name Bus controller Pin Function A23 output CS4-C output CS5-C output CS6-C output CS7-C output I/O port PF7 output PF7 input (initial setting) CS4-C A23_OE output 1 0 0 0 0 0 0 1 0 0 CS5-C output 1 0 0 CS6-C output 1 0 0 CS7-C output 1 0 0 PF7DDR 1 0
(2)
PF6/A22/CS6-D
The pin function is switched as shown below according to the combination of port function control register (PFCR) and the PF6DDR bit settings.
Setting I/O Port Module Name Bus controller Pin Function A22 output CS6-D output I/O port PF6 output PF6 input (initial setting) A22_OE 1 0 0 0 CS6D_OE 1 0 0 PF6DDR 1 0
Rev.2.00 Jun. 28, 2007 Page 283 of 666 REJ09B0311-0200
Section 8 I/O Ports
(3)
PF5/A21/CS5-D
The pin function is switched as shown below according to the combination of port function control register (PFCR) and the PF5DDR bit settings.
Setting I/O Port Module Name Bus controller Pin Function A21 output CS5-D output I/O port PF5 output PF5 input (initial setting) A21_OE 1 0 0 0 CS5D_OE 1 0 0 PF5DDR 1 0
(4)
PF4/A20
The pin function is always address output.
Setting I/O Port Module Name Bus controller Pin Function A20 output PF4DDR
(5)
PF3/A19
The pin function is always address output.
Setting I/O Port Module Name Bus controller Pin Function A19 output PF3DDR
Rev.2.00 Jun. 28, 2007 Page 284 of 666 REJ09B0311-0200
Section 8 I/O Ports
(6)
PF2/A18
The pin function is always address output.
Setting I/O Port Module Name Bus controller Pin Function A18 output PF2DDR
(7)
PF1/A17
The pin function is always address output.
Setting I/O Port Module Name Bus controller Pin Function A17 output PF1DDR
(8)
PF0/A16
The pin function is always address output.
Setting I/O Port Module Name Bus controller Pin Function A16 output PF0DDR
Rev.2.00 Jun. 28, 2007 Page 285 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.2.11 (1)
Port H
PH7/D7, PH6/D6, PH5/D5, PH4/D4, PH3/D3, PH2/D2, PH1/D1, PH0/D0
The pin function is always data input/output.
Setting I/O Port Module Name Bus controller Pin Function Data I/O (initial setting) PHnDDR
8.2.12 (1)
Port I
PI7/D15, PI6/D14, PI5/D13, PI4/D12, PI3/D11, PI2/D10, PI1/D9, PI0/D8
The pin function is switched as shown below according to the combination of operating mode, bus mode, and the PInDDR bit settings.
Setting Bus Controller Module Name Bus controller Pin Function Data I/O (mode 4 initial setting) PIn output PIn input (mode 5 initial setting) [Legend] n = 0 to 7 16-Bit Bus Mode 1 I/O Port PInDDR
I/O port
0 0
1 0
Rev.2.00 Jun. 28, 2007 Page 286 of 666 REJ09B0311-0200
Section 8 I/O Ports
Table 8.5
Available Output Signals and Settings in Each Port
Output Specification Output Signal Name SCK2 Signal Selection Register Settings Peripheral Module Settings When SCMR.SMIF = 1: SCR.TE = 1 or SCR.RE = 1 while SMR.GM = 0, SCR.CKE [1, 0] = 01 or while SMR.GM = 1 When SCMR.SMIF = 0: SCR.TE = 1 or SCR.RE = 1 while SMR.C/A = 0, SCR.CKE [1, 0] = 01 or while SMR.C/A = 1, SCR.CKE 1 = 0
Port P1 2
Signal Name SCK2_OE
0 P2 7
TxD2_OE TIOCB5_OE PO7_OE
TxD2 TIOCB5 PO7 TIOCA5 TMO1 TxD1 PO6 TIOCA4 PO5 TIOCB4 SCK1
SCR.TE = 1 TPU.TIOR5.IOB3 = 0, TPU.TIOR5.IOB[1,0] = 01/10/11 NDERL.NDER7 = 1 TPU.TIOR5.IOA3 = 0, TPU.TIOR5.IOA[1,0] = 01/10/11 TCSR.OS3,2 = 01/10/11 or TCSR.OS[1,0] = 01/10/11 SCR.TE = 1 NDERL.NDER6 = 1 TPU.TIOR4.IOA3 = 0, TPU.TIOR4.IOA[1,0] = 01/10/11 NDERL.NDER5 = 1 TPU.TIOR4.IOB3 = 0, TPU.TIOR4.IOB[1,0] = 01/10/11 When SCMR.SMIF = 1: SCR.TE = 1 or SCR.RE = 1 while SMR.GM = 0, SCR.CKE [1, 0] = 01 or while SMR.GM = 1 When SCMR.SMIF = 0: SCR.TE = 1 or SCR.RE = 1 while SMR.C/A = 0, SCR.CKE [1, 0] = 01 or while SMR.C/A = 1, SCR.CKE 1 = 0
6
TIOCA5_OE TMO1_OE TxD1_OE PO6_OE
5
TIOCA4_OE PO5_OE
4
TIOCB4_OE SCK1_OE
PO4_OE 3 TIOCD3_OE
PO4 TIOCD3
NDERL.NDER4 = 1 TPU.TMDR.BFB = 0, TPU.TIORL3.IOD3 = 0, TPU.TIORL3.IOD[1,0] = 01/10/11
PO3_OE
PO3
NDERL.NDER3 = 1
Rev.2.00 Jun. 28, 2007 Page 287 of 666 REJ09B0311-0200
Section 8 I/O Ports
Output Specification Port P2 2 Signal Name TIOCC3_OE
Output Signal Name TIOCC3 Signal Selection Register Settings Peripheral Module Settings TPU.TMDR.BFA = 0, TPU.TIORL3.IOC3 = 0, TPU.TIORL3.IOD[1,0] = 01/10/11
TMO0_OE TxD0_OE PO2_OE 1 TIOCA3_OE PO1_OE 0 TIOCB3_OE SCK0_OE
TMO0 TxD0 PO2 TIOCA3 PO1 TIOCB3 SCK0
TCSR.OS[3,2] = 01/10/11 or TCSR.OS[1,0] = 01/10/11 SCR.TE = 1 NDERL.NDER2 = 1 TPU.TIORH3.IOA3 = 0, TPU.TIORH3.IOA[1,0] = 01/10/11 NDERL.NDER1 = 1 TPU.TIORH3.IOB3 = 0, TPU.TIORH3.IOB[1,0] = 01/10/11 When SCMR.SMIF = 1: SCR.TE = 1 or SCR.RE = 1 while SMR.GM = 0, SCR.CKE [1, 0] = 01 or while SMR.GM = 1 When SCMR.SMIF = 0: SCR.TE = 1 or SCR.RE = 1 while SMR.C/A = 0, SCR.CKE [1, 0] = 01 or while SMR.C/A = 1, SCR.CKE 1 = 0
PO0_OE P3 7 TIOCB2_OE PO15_OE 6 TIOCA2_OE PO14_OE 5 TIOCB1_OE PO13_OE 4 TIOCA1_OE PO12_OE 3 TIOCD0_OE
PO0 TIOCB2 PO15 TIOCA2 PO14 TIOCB1 PO13 TIOCA1 PO12 TIOCD0
NDERL.NDER0 = 1 TPU.TIOR2.IOB3 = 0, TPU.TIOR2.IOB[1,0] = 01/10/11 NDERH.NDER15 = 1 TPU.TIOR2.IOA3 = 0, TPU.TIOR2.IOA[1,0] = 01/10/11 NDERH.NDER14 = 1 TPU.TIOR1.IOB3 = 0, TPU.TIOR1.IOB[1,0] = 01/10/11 NDERH.NDER13 = 1 TPU.TIOR1.IOA3 = 0, TPU.TIOR1.IOA[1,0] = 01/10/11 NDERH.NDER12 = 1 TPU.TMDR.BFB = 0, TPU.TIORL0.IOD3 = 0, TPU.TIORL0.IOD[1,0] = 01/10/11
PO11_OE 2 TIOCC0_OE
PO11 TIOCC0
NDERH.NDER11 = 1 TPU.TMDR.BFA = 0, TPU.TIORL0.IOC3 = 0, TPU.TIORL0.IOD[1,0] = 01/10/11
PO10_OE
PO10
NDERH.NDER10 = 1
Rev.2.00 Jun. 28, 2007 Page 288 of 666 REJ09B0311-0200
Section 8 I/O Ports
Output Specification Port P3 1 Signal Name TIOCB0_OE
Output Signal Name TIOCB0 Signal Selection Register Settings Peripheral Module Settings TPU.TIORH0.IOB3 = 0, TPU.TIORH0.IOB[1,0] = 01/10/11
PO9_OE 0 TIOCA0_OE
PO9 TIOCA0
NDERH.NDER9 = 1 TPU.TIORH0.IOA3 = 0, TPU.TIORH0.IOA[1,0] = 01/10/11
PO8_OE P6 5 2 TMO3_OE TMO2_OE SCK4_OE
PO8 TMO3 TMO2 SCK4
NDERH.NDER8 = 1 TCSR.OS[3,2] = 01/10/11 or TCSR.OS[1,0] = 01/10/11 TCSR.OS[3,2] = 01/10/11 or TCSR.OS[1,0] = 01/10/11 When SCMR.SMIF = 1: SCR.TE = 1 or SCR.RE = 1 while SMR.GM = 0, SCR.CKE [1, 0] = 01 or while SMR.GM = 1 When SCMR.SMIF = 0: SCR.TE = 1 or SCR.RE = 1 while SMR.C/A = 0, SCR.CKE [1, 0] = 01 or while SMR.C/A = 1, SCR.CKE 1 = 0
0 PA 7 6
TxD4_OE B_OE AH_OE BS-B_OE AS_OE
TxD4 B AH BS AS RD LUB LHWR LLB LLWR BACK RD/WR BS BREQO PFCR2.BSS = 0 PFCR2.BSS = 1
SCR.TE = 1 PADDR.PA7DDR = 1, SCKCR.POSEL1 = 0 MPXCR.MPXEn (n = 7 to 3) = 1 PFCR2.BSE = 1 PFCR2.ASOE = 1
5 4
RD_OE LUB_OE LHWR_OE
PFCR6.LHWROE = 1 or SRAMCR.BCSELn = 1 PFCR6.LHWROE = 1 SRAMCR.BCSELn = 1 SRAMCR.BCSELn = 0 BCR1.BRLE = 1 PFCR2.REWRE = 1 or SRAMCR.BCSELn = 1 PFCR2.BSE = 1 BCR1.BRLE = 1, BCR1.BREQOE = 1
3
LLB_OE LLWR_OE
1
BACK_OE (RD/WR)_OE
0
BS-A_OE BREQO_OE
Rev.2.00 Jun. 28, 2007 Page 289 of 666 REJ09B0311-0200
Section 8 I/O Ports
Output Specification Port PB 3 Signal Name CS3_OE CS7A_OE 2 CS2A_OE CS6A_OE 1 CS1_OE CS2B_OE CS5A_OE CS6B_OE CS7B_OE 0 CS0_OE CS4A_OE CS5B_OE PD 7 6 5 4 3 2 1 0 PE 7 6 5 4 3 2 1 0 A7_OE A6_OE A5_OE A4_OE A3_OE A2_OE A1_OE A0_OE A15_OE A14_OE A13_OE A12_OE A11_OE A10_OE A9_OE A8_OE
Output Signal Name CS3 CS7 CS2 CS6 CS1 CS2 CS5 CS6 CS7 CS0 CS4 CS5 A7 A6 A5 A4 A3 A2 A1 A0 A15 A14 A13 A12 A11 A10 A9 A8 PFCR1.CS4S[A,B] = 00 PFCR0.CS4E = 1 PFCR1.CS5S[A,B] = 01 PFCR0.CS5E = 1 PFCR2.CS2S = 1 PFCR1.CS5S[A,B] = 00 PFCR1.CS6S[A,B] = 01 PFCR1.CS7S[A,B] = 01 PFCR1.CS7S[A,B] = 00 PFCR2.CS2S = 0 PFCR1.CS6S[A,B] = 00 Signal Selection Register Settings Peripheral Module Settings PFCR0.CS3E = 1 PFCR0.CS7E = 1 PFCR0.CS2E = 1 PFCR0.CS6E = 1 PFCR0.CS1E = 1 PFCR0.CS2E = 1 PFCR0.CS5E = 1 PFCR0.CS6E = 1 PFCR0.CS7E = 1 PFCR0.CS0E = 1 PFCR0.CS4E = 1
Rev.2.00 Jun. 28, 2007 Page 290 of 666 REJ09B0311-0200
Section 8 I/O Ports
Output Specification Port PF 7 Signal Name A23_OE CS4C_OE CS5C_OE CS6C_OE CS7C_OE 6 A22_OE CS6D_OE 5 A21_OE CS5D_OE 4 3 2 1 0 PH 7 6 5 4 3 2 1 0 PI 7 6 5 4 3 2 1 0 A20_OE A19_OE A18_OE A17_OE A16_OE D7_E D6_E D5_E D4_E D3_E D2_E D1_E D0_E D15_E D14_E D13_E D12_E D11_E D10_E D9_E D8_E
Output Signal Name A23 CS4 CS5 CS6 CS7 A22 CS6 A21 CS5 A20 A19 A18 A17 A16 D7 D6 D5 D4 D3 D2 D1 D0 D15 D14 D13 D12 D11 D10 D9 D8 ABWCR.ABW[H,L]n = 01 ABWCR.ABW[H,L]n = 01 ABWCR.ABW[H,L]n = 01 ABWCR.ABW[H,L]n = 01 ABWCR.ABW[H,L]n = 01 ABWCR.ABW[H,L]n = 01 ABWCR.ABW[H,L]n = 01 ABWCR.ABW[H,L]n = 01 Signal Selection Register Settings Peripheral Module Settings PFCR4.A23E = 1 PFCR1.CS4S[A,B] = 10 PFCR1.CS5S[A,B] = 10 PFCR1.CS6S[A,B] = 10 PFCR1.CS7S[A,B] = 10 PFCR4.A22E = 1 PFCR1.CS6S[A,B] = 11 PFCR4.A21E = 1 PFCR1.CS5S[A,B] = 11 PFCR0.CS5E = 1 PFCR0.CS6E = 1 PFCR0.CS4E = 1 PFCR0.CS5E = 1 PFCR0.CS6E = 1 PFCR0.CS7E = 1
Rev.2.00 Jun. 28, 2007 Page 291 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.3
Port Function Controller
The port function controller controls the I/O ports. The port function controller incorporates the following registers. * * * * * * * * Port function control register 0 (PFCR0) Port function control register 1 (PFCR1) Port function control register 2 (PFCR2) Port function control register 4 (PFCR4) Port function control register 6 (PFCR6) Port function control register 9 (PFCR9) Port function control register B (PFCRB) Port function control register C (PFCRC) Port Function Control Register 0 (PFCR0)
8.3.1
PFCR0 enables/disables the CS output.
Bit Bit Name Initial Value R/W 7 CS7E 0 R/W 6 CS6E 0 R/W 5 CS5E 0 R/W 4 CS4E 0 R/W 3 CS3E 0 R/W 2 CS2E 0 R/W 1 CS1E 0 R/W 0 CS0E 1 R/W
Bit 7 6 5 4 3 2 1 0
Bit Name CS7E CS6E CS5E CS4E CS3E CS2E CS1E CS0E
Initial Value 0 0 0 0 0 0 0 1
R/W R/W R/W R/W R/W R/W R/W R/W R/W
Description CS7 to CS0 Enable These bits enable/disable the corresponding CSn output. 0: Pin functions as I/O port 1: Pin functions as CSn output pin (n = 7 to 0)
Rev.2.00 Jun. 28, 2007 Page 292 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.3.2
Port Function Control Register 1 (PFCR1)
PFCR1 selects the CS output pins.
Bit Bit Name Initial Value R/W 7 CS7SA 0 R/W 6 CS7SB 0 R/W 5 CS6SA 0 R/W 4 CS6SB 0 R/W 3 CS5SA 0 R/W 2 CS5SB 0 R/W 1 CS4SA 0 R/W 0 CS4SB 0 R/W
Bit 7 6
Bit Name CS7SA* CS7SB*
Initial Value 0 0
R/W R/W R/W
Description CS7 Output Pin Select Selects the output pin for CS7 when CS7 output is enabled (CS7E = 1) 00: Specifies pin PB3 as CS7-A output 01: Specifies pin PB1 as CS7-B output 10: Specifies pin PF7 as CS7-C output 11: Setting prohibited
5 4
CS6SA* CS6SB*
0 0
R/W R/W
CS6 Output Pin Select Selects the output pin for CS6 when CS6 output is enabled (CS6E = 1) 00: Specifies pin PB2 as CS6-A output 01: Specifies pin PB1 as CS6-B output 10: Specifies pin PF7 as CS6-C output 11: Specifies pin PF6 as CS6-D output
3 2
CS5SA* CS5SB*
0 0
R/W R/W
CS5 Output Pin Select Selects the output pin for CS5 when CS5 output is enabled (CS5E = 1) 00: Specifies pin PB1 as CS5-A output 01: Specifies pin PB0 as CS5-B output 10: Specifies pin PF7 as CS5-C output 11: Specifies pin PF5 as CS5-D output
Rev.2.00 Jun. 28, 2007 Page 293 of 666 REJ09B0311-0200
Section 8 I/O Ports
Bit 1 0
Bit Name CS4SA* CS4SB*
Initial Value 0 0
R/W R/W R/W
Description CS4 Output Pin Select Selects the output pin for CS4 when CS4 output is enabled (CS4E = 1) 00: Specifies pin PB0 as CS4-A output 01: Setting prohibited 10: Specifies pin PF7 as CS4-C output 11: Setting prohibited
Note:
*
If multiple CS outputs are specified to a single pin according to the CSn output pin select bits (n = 4 to 7), multiple CS signals are output from the pin. For details, see section 6.5.3, Chip Select Signals.
8.3.3
Port Function Control Register 2 (PFCR2)
PFCR1 selects the CS output pin, enables/disables bus control I/O, and selects the bus control I/O pins.
Bit Bit Name Initial Value R/W 7 0 R/W 6 CS2S 0 R/W 5 BSS 0 R/W 4 BSE 0 R/W 3 0 R/W 2 RDWRE 0 R/W 1 ASOE 1 R/W 0 0 R/W
Bit 7
Bit Name
Initial Value 0
R/W R/W
Description Reserved This bit is always read as 0. The write value should always be 0.
6
CS2S*1
0
R/W
CS2 Output Pin Select Selects the output pin for CS2 when CS2 output is enabled (CS2E = 1) 0: Specifies pin PB2 as CS2-A output pin 1: Specifies pin PB1 as CS2-B output pin
5
BSS
0
R/W
BS Output Pin Select Selects the BS output pin 0: Specifies pin PA0 as BS-A output pin 1: Specifies pin PA6 as BS-B output pin
Rev.2.00 Jun. 28, 2007 Page 294 of 666 REJ09B0311-0200
Section 8 I/O Ports
Bit 4
Bit Name BSE
Initial Value 0
R/W R/W
Description BS Output Enable Enables/disables the BS output 0: Disables the BS output 1: Enables the BS output
3
0
R/W
Reserved This bit is always read as 0. The write value should always be 0.
2
RDWRE*2 0
R/W
RD/WR Output Enable Enables/disables the RD/WR output 0: Disables the RD/WR output 1: Enables the RD/WR output
1
ASOE
1
R/W
AS Output Enable Enables/disables the AS output 0: Specifies pin PA6 as I/O port 1: Specifies pin PA6 as AS output pin
0
0
R/W
Reserved This bit is always read as 0. The write value should always be 0.
Notes: 1. If multiple CS outputs are specified to a single pin according to the CSn output pin select bits (n = 2), multiple CS signals are output from the pin. For details, see section 6.5.3, Chip Select Signals. 2. If an area is specified as a byte control SDRAM space, the pin functions as RD/WR output.
Rev.2.00 Jun. 28, 2007 Page 295 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.3.4
Port Function Control Register 4 (PFCR4)
PFCR4 enables/disables the address output.
Bit Bit Name Initial Value R/W 7 A23E 0 R/W 6 A22E 0 R/W 5 A21E 0 R/W 4 1 R/W 3 1 R/W 2 1 R/W 1 1 R/W 0 1 R/W
Bit 7
Bit Name A23E
Initial Value 0
R/W R/W
Description Address A23 Enable Enables/disables the address output (A23) 0: Disables the A23 output 1: Enables the A23 output
6
A22E
0
R/W
Address A22 Enable Enables/disables the address output (A22) 0: Disables the A22 output 1: Enables the A22 output
5
A21E
0
R/W
Address A21 Enable Enables/disables the address output (A21) 0: Disables the A21 output 1: Enables the A21 output
4 to 0
All 1
R/W
Reserved These bits are always read as 1. The write value should always be 1.
Rev.2.00 Jun. 28, 2007 Page 296 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.3.5
Port Function Control Register 6 (PFCR6)
PFCR6 selects the TPU clock input pin.
Bit Bit Name Initial Value R/W 7 1 R/W 6 LHWROE 1 R/W 5 1 R/W 4 0 R 3 TCLKS 0 R/W 2 0 R/W 1 0 R/W 0 0 R/W
Bit 7
Bit Name
Initial Value 1
R/W R/W
Description Reserved This bit is always read as 1. The write value should always be 1.
6
LHWROE
1
R/W
LHWR Output Enable Enables/disables LHWR output (valid in external extended mode). 0: Specifies pin PA4 as I/O port 1: Specifies pin PA4 as LHWR output pin
5
1
R/W
Reserved This bit is always read as 1. The write value should always be 1.
4 3
TCLKS
0 0
R R/W
Reserved This is a read-only bit and cannot be modified. TPU External Clock Input Pin Select Selects the TPU external clock input pins. 0: Specifies pins P32, P33, P35, and P37 as external clock inputs 1: Specifies pins P14 to P17 as external clock inputs
2 to 0
All 0
R/W
Reserved These bits are always read as 0. The write value should always be 0.
Rev.2.00 Jun. 28, 2007 Page 297 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.3.6
Port Function Control Register 9 (PFCR9)
PFCR9 selects the multiple functions for the TPU I/O pins.
Bit Bit Name Initial Value R/W 7 TPUMS5 0 R/W 6 TPUMS4 0 R/W 5 TPUMS3A 0 R/W 4 TPUMS3B 0 R/W 3 TPUMS2 0 R/W 2 TPUMS1 0 R/W 1 TPUMS0A 0 R/W 0 TPUMS0B 0 R/W
Bit 7
Bit Name TPUMS5
Initial Value 0
R/W R/W
Description TPU I/O Pin Multiplex Function Select Selects TIOCA5 function 0: Specifies pin P26 as output compare output and input capture 1: Specifies P27 as input capture input and P26 as output compare
6
TPUMS4
0
R/W
TPU I/O Pin Multiplex Function Select Selects TIOCA4 function 0: Specifies P25 as output compare output and input capture 1: Specifies P24 as input capture input and P25 as output compare
5
TPUMS3A 0
R/W
TPU I/O Pin Multiplex Function Select Selects TIOCA3 function 0: Specifies P21 as output compare output and input capture 1: Specifies P20 as input capture input and P21 as output compare
4
TPUMS3B 0
R/W
TPU I/O Pin Multiplex Function Select Selects TIOCC3 function 0: Specifies P22 as output compare output and input capture 1: Specifies P23 as input capture input and P22 as output compare
Rev.2.00 Jun. 28, 2007 Page 298 of 666 REJ09B0311-0200
Section 8 I/O Ports
Bit 3
Bit Name TPUMS2
Initial Value 0
R/W R/W
Description TPU I/O Pin Multiplex Function Select Selects TIOCA2 function 0: Specifies P36 as output compare output and input capture 1: Specifies P37 as input capture input and P36 as output compare
2
TPUMS1
0
R/W
TPU I/O Pin Multiplex Function Select Selects TIOCA1 function 0: Specifies P34 as output compare output and input capture 1: Specifies P35 as input capture input and P34 as output compare
1
TPUMS0A 0
R/W
TPU I/O Pin Multiplex Function Select Selects TIOCA0 function 0: Specifies P30 as output compare output and input capture 1: Specifies P31 as input capture input and P30 as output compare
0
TPUMS0B 0
R/W
TPU I/O Pin Multiplex Function Select Selects TIOCC0 function 0: Specifies P32 as output compare output and input capture 1: Specifies P33 as input capture input and P32 as output compare
Rev.2.00 Jun. 28, 2007 Page 299 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.3.7
Port Function Control Register B (PFCRB)
PFCRB selects the input pins for IRQ11 to IRQ8.
Bit Bit Name Initial Value R/W 7 0 R/W 6 0 R/W 5 0 R/W 4 0 R/W 3 ITS11 0 R/W 2 ITS10 0 R/W 1 ITS9 0 R/W 0 ITS8 0 R/W
Bit 7 to 4
Bit Name
Initial Value All 0
R/W R/W
Description Reserved These bits are always read as 0. The write value should always be 0.
3
ITS11
0
R/W
IRQ11 Pin Select Selects an input pin for IRQ11. 0: Selects pin P23 as IRQ11-A input 1: Selects pin P63 as IRQ11-B input
2
ITS10
0
R/W
IRQ10 Pin Select Selects an input pin for IRQ10. 0: Selects pin P22 as IRQ10-A input 1: Selects pin P62 as IRQ10-B input
1
ITS9
0
R/W
IRQ9 Pin Select Selects an input pin for IRQ9. 0: Selects pin P21 as IRQ9-A input 1: Selects pin P61 as IRQ9-B input
0
ITS8
0
R/W
IRQ8 Pin Select Selects an input pin for IRQ8. 0: Selects pin P20 as IRQ8-A input 1: Selects pin P60 as IRQ8-B input
Rev.2.00 Jun. 28, 2007 Page 300 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.3.8
Port Function Control Register C (PFCRC)
PFCRC selects input pins for IRQ7 to IRQ0.
Bit Bit Name Initial Value R/W 7 ITS7 0 R/W 6 ITS6 0 R/W 5 ITS5 0 R/W 4 ITS4 0 R/W 3 ITS3 0 R/W 2 ITS2 0 R/W 1 ITS1 0 R/W 0 ITS0 0 R/W
Bit 7
Bit Name ITS7
Initial Value 0
R/W R/W
Description IRQ7 Pin Select Selects an input pin for IRQ7. 0: Selects pin P17 as IRQ7-A input 1: Selects pin P57 as IRQ7-B output
6
ITS6
0
R/W
IRQ6 Pin Select Selects an input pin for IRQ6. 0: Selects pin P16 as IRQ6-A input 1: Selects pin P56 as IRQ6-B output
5
ITS5
0
R/W
IRQ5 Pin Select Selects an input pin for IRQ5. 0: Selects pin P15 as IRQ5-A input 1: Selects pin P55 as IRQ5-B output
4
ITS4
0
R/W
IRQ4 Pin Select Selects an input pin for IRQ4. 0: Selects pin P14 as IRQ4-A input 1: Selects pin P54 as IRQ4-B output
3
ITS3
0
R/W
IRQ3 Pin Select Selects an input pin for IRQ3. 0: Selects pin P13 as IRQ3-A input 1: Selects pin P53 as IRQ3-B output
Rev.2.00 Jun. 28, 2007 Page 301 of 666 REJ09B0311-0200
Section 8 I/O Ports
Bit 2
Bit Name ITS2
Initial Value 0
R/W R/W
Description IRQ2 Pin Select Selects an input pin for IRQ2. 0: Selects pin P12 as IRQ2-A input 1: Selects pin P52 as IRQ2-B output
1
ITS1
0
R/W
IRQ1 Pin Select Selects an input pin for IRQ1. 0: Selects pin P11 as IRQ1-A input 1: Selects pin P51 as IRQ1-B output
0
ITS0
0
R/W
IRQ0 Pin Select Selects an input pin for IRQ0. 0: Selects pin P10 as IRQ0-A input 1: Selects pin P50 as IRQ0-B output
Rev.2.00 Jun. 28, 2007 Page 302 of 666 REJ09B0311-0200
Section 8 I/O Ports
8.4
8.4.1
Usage Notes
Notes on Input Buffer Control Register (ICR) Setting
* When changing the ICR setting, the LSI may malfunction due to an edge that is internally generated according to the pin states. To change the ICR setting, fix the pin high or disable the input function by setting the peripheral module allocated to the corresponding pin. * If an input is enabled by setting ICR while multiple input functions are assigned to the pin, the pin state is reflected in all the inputs. Care must be taken for each module settings for unused input functions. * When a pin is used as an output, data to be output from the pin will be latched as the pin state if the input by the ICR setting is enabled. To use the pin as an output, disable the input function for the pin by setting ICR. 8.4.2 Notes on Port Function Control Register (PFCR) Settings
* The port function controller controls the I/O ports. To set the input/output to each pin, select the input/output destination and then enable input/output. * When changing the input pin, an edge may be generated if the previous pin level differs from the pin level after the change, causing an unintended malfunction. To change the input pin, follow the procedure below. (1) Disable the input function by the setting of the peripheral module corresponding to the pin to be changed. (2) Select the input pin by the setting of PFCR. (3) Enable the input function by the setting of the peripheral module corresponding to the pin to be changed. * If a pin function has both a selection bit that modifies the input/output destination and an enable bit that enables the pin function, first specify the input/output destination by the selection bit and then enable the pin function by the enable bit.
Rev.2.00 Jun. 28, 2007 Page 303 of 666 REJ09B0311-0200
Section 8 I/O Ports
Rev.2.00 Jun. 28, 2007 Page 304 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Section 9 16-Bit Timer Pulse Unit (TPU)
This LSI has an on-chip 16-bit timer pulse unit (TPU) that comprises six 16-bit timer channels. Tables 9.1 lists the 16-bit timer unit functions and figure 9.1 is a block diagram.
9.1
Features
* Maximum 16-pulse input/output * Selection of eight counter input clocks for each channel * The following operations can be set for each channel: Waveform output at compare match Input capture function Counter clear operation Synchronous operations: * Multiple timer counters (TCNT) can be written to simultaneously * Simultaneous clearing by compare match and input capture possible * Simultaneous input/output for registers possible by counter synchronous operation * Maximum of 15-phase PWM output possible by combination with synchronous operation * Buffer operation settable for channels 0 and 3 * Phase counting mode settable independently for each of channels 1, 2, 4, and 5 * Cascaded operation * Fast access via internal 16-bit bus * 26 interrupt sources * Automatic transfer of register data * Programmable pulse generator (PPG) output trigger can be generated * Conversion start trigger for the A/D converter can be generated * Module stop state specifiable
Rev.2.00 Jun. 28, 2007 Page 305 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.1
Item Count clock
TPU Functions
Channel 0 Channel 1 Channel 2 Channel 3 Channel 4 Channel 5 P/1 P/4 P/16 P/64 TCLKA TCLKB TCLKC TCLKD TGRA_0 TGRB_0 TGRC_0 TGRD_0 TIOCA0 TIOCB0 TIOCC0 TIOCD0 P/1 P/4 P/16 P/64 P/256 TCLKA TCLKB TCNT2 TGRA_1 TGRB_1 TIOCA1 TIOCB1 P/1 P/4 P/16 P/64 P/1024 TCLKA TCLKB TCLKC TGRA_2 TGRB_2 TIOCA2 TIOCB2 P/1 P/4 P/16 P/64 P/256 P/1024 P/4096 TCLKA TGRA_3 TGRB_3 TGRC_3 TGRD_3 TIOCA3 TIOCB3 TIOCC3 TIOCD3 TGR compare match or input capture O O O O O O O TGR compare match or input capture P/1 P/4 P/16 P/64 P/1024 TCLKA TCLKC TCNT5 TGRA_4 TGRB_4 TIOCA4 TIOCB4 P/1 P/4 P/16 P/64 P/256 TCLKA TCLKC TCLKD TGRA_5 TGRB_5 TIOCA5 TIOCB5
General registers (TGR) General registers/ buffer registers I/O pins
Counter clear function TGR compare match or input capture Compare 0 output match 1 output output Toggle output O O O
TGR compare match or input capture O O O O O O O TGR compare match or input capture
TGR compare match or input capture O O O O O O O TGR compare match or input capture
TGR compare match or input capture O O O O O O O TGR compare match or input capture
TGR compare match or input capture O O O O O O O TGR compare match or input capture
Input capture function O Synchronous operation PWM mode O O
Phase counting mode Buffer operation DTC activation O TGR compare match or input capture
Rev.2.00 Jun. 28, 2007 Page 306 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Item A/D converter trigger
Channel 0 Channel 1 Channel 2 Channel 3 Channel 4 Channel 5 TGRA_0 compare match or input capture TGRA_0/ TGRB_0 compare match or input capture 5 sources Compare match or input capture 0A Compare match or input capture 0B TGRA_1 compare match or input capture TGRA_1/ TGRB_1 compare match or input capture 4 sources Compare match or input capture 1A Compare match or input capture 1B TGRA_2 compare match or input capture TGRA_2/ TGRB_2 compare match or input capture 4 sources Compare match or input capture 2A Compare match or input capture 2B Overflow Underflow TGRA_3 compare match or input capture TGRA_3/ TGRB_3 compare match or input capture 5 sources Compare match or input capture 3A Compare match or input capture 3B TGRA_4 compare match or input capture TGRA_5 compare match or input capture
PPG trigger
Interrupt sources
4 sources Compare match or input capture 4A Compare match or input capture 4B
4 sources Compare match or input capture 5A Compare match or input capture 5B Overflow Underflow
Compare Overflow match or Underflow input capture 0C Compare match or input capture 0D Overflow [Legend] Possible O: : Not possible
Compare Overflow match or Underflow input capture 3C Compare match or input capture 3D Overflow
Rev.2.00 Jun. 28, 2007 Page 307 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
TCR TMDR TIORH TIORL TIER TSR
Channel 3
TCNT TGRA TGRB TGRC TGRD
Control logic for channels 3 to 5
Input/output pins Channel 3: TIOCA3 TIOCB3 TIOCC3 TIOCD3 Channel 4: TIOCA4 TIOCB4 Channel 5: TIOCA5 TIOCB5
TCR TMDR TIOR TIER TSR
Channel 5
TCR TMDR TIOR TIER TSR
Channel 2
Clock input Internal clock:P/1 P/4 P/16 P/64 P/256 P/1024 P/4096 External clock: TCLKA TCLKB TCLKC TCLKD
Module data bus
TSTR TSYR
Control logic
Bus interface
TCNT TGRA TGRB
Interrupt request signals Channel 3: TGI3A TGI3B TGI3C TGI3D TCI3V Channel 4: TGI4A TGI4B TCI4V TCI4U Channel 5: TGI5A TGI5B TCI5V TCI5U
TCR TMDR TIOR TIER TSR
Channel 4
TCNT TGRA TGRB
Internal data bus A/D conversion start request signal PPG output trigger signal
Common
TCNT TGRA TGRB
Control logic for channels 0 to 2
TCR TMDR TIORH TIORL TIER TSR
Input/output pins Channel 0: TIOCA0 TIOCB0 TIOCC0 TIOCD0 Channel 1: TIOCA1 TIOCB1 Channel 2: TIOCA2 TIOCB2
Interrupt request signals Channel 0: TGI0A TGI0B TGI0C TGI0D TCI0V Channel 1: TGI1A TGI1B TCI1V TCI1U Channel 2: TGI2A TGI2B TCI2V TCI2U
TCR TMDR TIOR TIER TSR
Channel 1
Channel 0
[Legend] TSTR: Timer start register TSYR: Timer synchronous register TCR: Timer control register TMDR: Timer mode register TIOR (H, L): Timer I/O control registers (H, L)
TIER: Timer interrupt enable register TSR: Timer status register TGR (A, B, C, D): Timer general registers (A, B, C, D) TCNT: Timer counter
Figure 9.1 Block Diagram of TPU
Rev.2.00 Jun. 28, 2007 Page 308 of 666 REJ09B0311-0200
TCNT TGRA TGRB TGRC TGRD
TCNT TGRA TGRB
Section 9 16-Bit Timer Pulse Unit (TPU)
9.2
Input/Output Pins
Table 9.3 shows TPU pin configurations. Table 9.2 Pin Configuration
I/O Function
Channel Symbol All TCLKA TCLKB TCLKC TCLKD 0 TIOCA0 TIOCB0 TIOCC0 TIOCD0 1 TIOCA1 TIOCB1 2 TIOCA2 TIOCB2 3 TIOCA3 TIOCB3 TIOCC3 TIOCD3 4 TIOCA4 TIOCB4 5 TIOCA5 TIOCB5
Input External clock A input pin (Channel 1 and 5 phase counting mode A phase input) Input External clock B input pin (Channel 1 and 5 phase counting mode B phase input) Input External clock C input pin (Channel 2 and 4 phase counting mode A phase input) Input External clock D input pin (Channel 2 and 4 phase counting mode B phase input) I/O I/O I/O I/O I/O I/O I/O I/O I/O I/O I/O I/O I/O I/O I/O I/O TGRA_0 input capture input/output compare output/PWM output pin TGRB_0 input capture input/output compare output/PWM output pin TGRC_0 input capture input/output compare output/PWM output pin TGRD_0 input capture input/output compare output/PWM output pin TGRA_1 input capture input/output compare output/PWM output pin TGRB_1 input capture input/output compare output/PWM output pin TGRA_2 input capture input/output compare output/PWM output pin TGRB_2 input capture input/output compare output/PWM output pin TGRA_3 input capture input/output compare output/PWM output pin TGRB_3 input capture input/output compare output/PWM output pin TGRC_3 input capture input/output compare output/PWM output pin TGRD_3 input capture input/output compare output/PWM output pin TGRA_4 input capture input/output compare output/PWM output pin TGRB_4 input capture input/output compare output/PWM output pin TGRA_5 input capture input/output compare output/PWM output pin TGRB_5 input capture input/output compare output/PWM output pin
Rev.2.00 Jun. 28, 2007 Page 309 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.3
Register Descriptions
The TPU has the following registers in each channel. * Channel 0 Timer control register_0 (TCR_0) Timer mode register_0 (TMDR_0) Timer I/O control register H_0 (TIORH_0) Timer I/O control register L_0 (TIORL_0) Timer interrupt enable register_0 (TIER_0) Timer status register_0 (TSR_0) Timer counter_0 (TCNT_0) Timer general register A_0 (TGRA_0) Timer general register B_0 (TGRB_0) Timer general register C_0 (TGRC_0) Timer general register D_0 (TGRD_0) * Channel 1 Timer control register_1 (TCR_1) Timer mode register_1 (TMDR_1) Timer I/O control register _1 (TIOR_1) Timer interrupt enable register_1 (TIER_1) Timer status register_1 (TSR_1) Timer counter_1 (TCNT_1) Timer general register A_1 (TGRA_1) Timer general register B_1 (TGRB_1) * Channel 2 Timer control register_2 (TCR_2) Timer mode register_2 (TMDR_2) Timer I/O control register_2 (TIOR_2) Timer interrupt enable register_2 (TIER_2) Timer status register_2 (TSR_2) Timer counter_2 (TCNT_2) Timer general register A_2 (TGRA_2) Timer general register B_2 (TGRB_2)
Rev.2.00 Jun. 28, 2007 Page 310 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
* Channel 3 Timer control register_3 (TCR_3) Timer mode register_3 (TMDR_3) Timer I/O control register H_3 (TIORH_3) Timer I/O control register L_3 (TIORL_3) Timer interrupt enable register_3 (TIER_3) Timer status register_3 (TSR_3) Timer counter_3 (TCNT_3) Timer general register A_3 (TGRA_3) Timer general register B_3 (TGRB_3) Timer general register C_3 (TGRC_3) Timer general register D_3 (TGRD_3) * Channel 4 Timer control register_4 (TCR_4) Timer mode register_4 (TMDR_4) Timer I/O control register _4 (TIOR_4) Timer interrupt enable register_4 (TIER_4) Timer status register_4 (TSR_4) Timer counter_4 (TCNT_4) Timer general register A_4 (TGRA_4) Timer general register B_4 (TGRB_4) * Channel 5 Timer control register_5 (TCR_5) Timer mode register_5 (TMDR_5) Timer I/O control register_5 (TIOR_5) Timer interrupt enable register_5 (TIER_5) Timer status register_5 (TSR_5) Timer counter_5 (TCNT_5) Timer general register A_5 (TGRA_5) Timer general register B_5 (TGRB_5) * Common Registers Timer start register (TSTR) Timer synchronous register (TSYR)
Rev.2.00 Jun. 28, 2007 Page 311 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.3.1
Timer Control Register (TCR)
TCR controls the TCNT operation for each channel. The TPU has a total of six TCR registers, one for each channel. TCR register settings should be made only while TCNT operation is stopped.
Bit Bit Name Initial Value R/W 7 CCLR2 0 R/W 6 CCLR1 0 R/W 5 CCLR0 0 R/W 4 CKEG1 0 R/W 3 CKEG0 0 R/W 2 TPSC2 0 R/W 1 TPSC1 0 R/W 0 TPSC0 0 R/W
Bit 7 6 5 4 3
Bit Name CCLR2 CCLR1 CCLR0 CKEG1 CKEG0
Initial Value 0 0 0 0 0
R/W R/W R/W R/W R/W R/W
Description Counter Clear 2 to 0 These bits select the TCNT counter clearing source. See tables 9.3 and 9.4 for details. Clock Edge 1 and 0 These bits select the input clock edge. For details, see table 9.5. When the input clock is counted using both edges, the input clock period is halved (e.g. P/4 both edges = P/2 rising edge). If phase counting mode is used on channels 1, 2, 4, and 5, this setting is ignored and the phase counting mode setting has priority. Internal clock edge selection is valid when the input clock is P/4 or slower. This setting is ignored if the input clock is P/1, or when overflow/underflow of another channel is selected. Timer Prescaler 2 to 0 These bits select the TCNT counter clock. The clock source can be selected independently for each channel. See tables 9.6 to 9.11 for details. To select the external clock as the clock source, the DDR bit and ICR bit for the corresponding pin should be set to 0 and 1, respectively. For details, see section 8, I/O Ports.
2 1 0
TPSC2 TPSC1 TPSC0
0 0 0
R/W R/W R/W
Rev.2.00 Jun. 28, 2007 Page 312 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.3
Channel 0, 3
CCLR2 to CCLR0 (Channels 0 and 3)
Bit 7 CCLR2 0 0 0 0 Bit 6 CCLR1 0 0 1 1 Bit 5 CCLR0 0 1 0 1 Description TCNT clearing disabled TCNT cleared by TGRA compare match/input capture TCNT cleared by TGRB compare match/input capture TCNT cleared by counter clearing for another channel performing synchronous clearing/ 1 synchronous operation* TCNT clearing disabled TCNT cleared by TGRC compare match/input 2 capture* TCNT cleared by TGRD compare match/input capture*2 TCNT cleared by counter clearing for another channel performing synchronous clearing/ 1 synchronous operation*
1 1 1 1
0 0 1 1
0 1 0 1
Notes: 1. Synchronous operation is selected by setting the SYNC bit in TSYR to 1. 2. When TGRC or TGRD is used as a buffer register, TCNT is not cleared because the buffer register setting has priority, and compare match/input capture does not occur.
Rev.2.00 Jun. 28, 2007 Page 313 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.4
CCLR2 to CCLR0 (Channels 1, 2, 4, and 5)
Bit 7 Reserved *2 0 0 0 0 Bit 6 CCLR1 0 0 1 1 Bit 5 CCLR0 0 1 0 1
Channel 1, 2, 4, 5
Description TCNT clearing disabled TCNT cleared by TGRA compare match/input capture TCNT cleared by TGRB compare match/input capture TCNT cleared by counter clearing for another channel performing synchronous clearing/ 1 synchronous operation*
Notes: 1. Synchronous operation is selected by setting the SYNC bit in TSYR to 1. 2. Bit 7 is reserved in channels 1, 2, 4, and 5. It is always read as 0 and cannot be modified.
Table 9.5
Input Clock Edge Selection
Input Clock Internal Clock Counted at falling edge Counted at rising edge Counted at both edges External Clock Counted at rising edge Counted at falling edge Counted at both edges
Clock Edge Selection CKEG1 0 0 1 CKEG0 0 1 X
[Legend] X: Don't care
Rev.2.00 Jun. 28, 2007 Page 314 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.6
Channel 0
TPSC2 to TPSC0 (Channel 0)
Bit 2 TPSC2 0 0 0 0 1 1 1 1 Bit 1 TPSC1 0 0 1 1 0 0 1 1 Bit 0 TPSC0 0 1 0 1 0 1 0 1 Description Internal clock: counts on P/1 Internal clock: counts on P/4 Internal clock: counts on P/16 Internal clock: counts on P/64 External clock: counts on TCLKA pin input External clock: counts on TCLKB pin input External clock: counts on TCLKC pin input External clock: counts on TCLKD pin input
Table 9.7
Channel 1
TPSC2 to TPSC0 (Channel 1)
Bit 2 TPSC2 0 0 0 0 1 1 1 1 Bit 1 TPSC1 0 0 1 1 0 0 1 1 Bit 0 TPSC0 0 1 0 1 0 1 0 1 Description Internal clock: counts on P/1 Internal clock: counts on P/4 Internal clock: counts on P/16 Internal clock: counts on P/64 External clock: counts on TCLKA pin input External clock: counts on TCLKB pin input Internal clock: counts on P/256 Counts on TCNT2 overflow/underflow
Note: This setting is ignored when channel 1 is in phase counting mode.
Rev.2.00 Jun. 28, 2007 Page 315 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.8
Channel 2
TPSC2 to TPSC0 (Channel 2)
Bit 2 TPSC2 0 0 0 0 1 1 1 1 Bit 1 TPSC1 0 0 1 1 0 0 1 1 Bit 0 TPSC0 0 1 0 1 0 1 0 1 Description Internal clock: counts on P/1 Internal clock: counts on P/4 Internal clock: counts on P/16 Internal clock: counts on P/64 External clock: counts on TCLKA pin input External clock: counts on TCLKB pin input External clock: counts on TCLKC pin input Internal clock: counts on P/1024
Note: This setting is ignored when channel 2 is in phase counting mode.
Table 9.9
Channel 3
TPSC2 to TPSC0 (Channel 3)
Bit 2 TPSC2 0 0 0 0 1 1 1 1 Bit 1 TPSC1 0 0 1 1 0 0 1 1 Bit 0 TPSC0 0 1 0 1 0 1 0 1 Description Internal clock: counts on P/1 Internal clock: counts on P/4 Internal clock: counts on P/16 Internal clock: counts on P/64 External clock: counts on TCLKA pin input Internal clock: counts on P/1024 Internal clock: counts on P/256 Internal clock: counts on P/4096
Rev.2.00 Jun. 28, 2007 Page 316 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.10 TPSC2 to TPSC0 (Channel 4)
Channel 4 Bit 2 TPSC2 0 0 0 0 1 1 1 1 Bit 1 TPSC1 0 0 1 1 0 0 1 1 Bit 0 TPSC0 0 1 0 1 0 1 0 1 Description Internal clock: counts on P/1 Internal clock: counts on P/4 Internal clock: counts on P/16 Internal clock: counts on P/64 External clock: counts on TCLKA pin input External clock: counts on TCLKC pin input Internal clock: counts on P/1024 Counts on TCNT5 overflow/underflow
Note: This setting is ignored when channel 4 is in phase counting mode.
Table 9.11 TPSC2 to TPSC0 (Channel 5)
Channel 5 Bit 2 TPSC2 0 0 0 0 1 1 1 1 Bit 1 TPSC1 0 0 1 1 0 0 1 1 Bit 0 TPSC0 0 1 0 1 0 1 0 1 Description Internal clock: counts on P/1 Internal clock: counts on P/4 Internal clock: counts on P/16 Internal clock: counts on P/64 External clock: counts on TCLKA pin input External clock: counts on TCLKC pin input Internal clock: counts on P/256 External clock: counts on TCLKD pin input
Note: This setting is ignored when channel 5 is in phase counting mode.
Rev.2.00 Jun. 28, 2007 Page 317 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.3.2
Timer Mode Register (TMDR)
TMDR sets the operating mode for each channel. The TPU has six TMDR registers, one for each channel. TMDR register settings should be made only while TCNT operation is stopped.
Bit Bit Name Initial Value R/W 7 1 R 6 1 R 5 BFB 0 R/W 4 BFA 0 R/W 3 MD3 0 R/W 2 MD2 0 R/W 1 MD1 0 R/W 0 MD0 0 R/W
Bit 7, 6 5
Bit Name
Initial Value All 1 0
R/W R R/W
Description Reserved These are read-only bits and cannot be modified. Buffer Operation B Specifies whether TGRB is to normally operate, or TGRB and TGRD are to be used together for buffer operation. When TGRD is used as a buffer register, TGRD input capture/output compare is not generated. In channels 1, 2, 4, and 5, which have no TGRD, bit 5 is reserved. It is always read as 0 and cannot be modified. 0: TGRB operates normally 1: TGRB and TGRD used together for buffer operation
BFB
4
BFA
0
R/W
Buffer Operation A Specifies whether TGRA is to normally operate, or TGRA and TGRC are to be used together for buffer operation. When TGRC is used as a buffer register, TGRC input capture/output compare is not generated. In channels 1, 2, 4, and 5, which have no TGRC, bit 4 is reserved. It is always read as 0 and cannot be modified. 0: TGRA operates normally 1: TGRA and TGRC used together for buffer operation
3 2 1 0
MD3 MD2 MD1 MD0
0 0 0 0
R/W R/W R/W R/W
Modes 3 to 0 Set the timer operating mode. MD3 is a reserved bit. The write value should always be 0. See table 9.12 for details.
Rev.2.00 Jun. 28, 2007 Page 318 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.12 MD3 to MD0
Bit 3 1 MD3* 0 0 0 0 0 0 0 0 1 Bit 2 MD2*2 0 0 0 0 1 1 1 1 X Bit 1 MD1 0 0 1 1 0 0 1 1 X Bit 0 MD0 0 1 0 1 0 1 0 1 X Description Normal operation Reserved PWM mode 1 PWM mode 2 Phase counting mode 1 Phase counting mode 2 Phase counting mode 3 Phase counting mode 4
[Legend] X: Don't care Notes: 1. MD3 is a reserved bit. The write value should always be 0. 2. Phase counting mode cannot be set for channels 0 and 3. In this case, 0 should always be written to MD2.
9.3.3
Timer I/O Control Register (TIOR)
TIOR controls TGR. The TPU has eight TIOR registers, two each for channels 0 and 3, and one each for channels 1, 2, 4, and 5. Care is required since TIOR is affected by the TMDR setting. The initial output specified by TIOR is valid when the counter is stopped (the CST bit in TSTR is cleared to 0). Note also that, in PWM mode 2, the output at the point at which the counter is cleared to 0 is specified. When TGRC or TGRD is designated for buffer operation, this setting is invalid and the register operates as a buffer register. To designate the input capture pin in TIOR, the DDR bit and ICR bit for the corresponding pin should be set to 0 and 1, respectively. For details, see section 8, I/O Ports.
Rev.2.00 Jun. 28, 2007 Page 319 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
* TIORH_0, TIOR_1, TIOR_2, TIORH_3, TIOR_4, TIOR_5
Bit Bit Name Initial Value R/W 7 IOB3 0 R/W 6 IOB2 0 R/W 5 IOB1 0 R/W 4 IOB0 0 R/W 3 IOA3 0 R/W 2 IOA2 0 R/W 1 IOA1 0 R/W 0 IOA0 0 R/W
* TIORL_0, TORL_3
Bit Bit Name Initial Value R/W 7 IOD3 0 R/W 6 IOD2 0 R/W 5 IOD1 0 R/W 4 IOD0 0 R/W 3 IOC3 0 R/W 2 IOC2 0 R/W 1 IOC1 0 R/W 0 IOC0 0 R/W
* TIORH_0, TIOR_1, TIOR_2, TIORH_3, TIOR_4, TIOR_5
Bit 7 6 5 4 3 2 1 0 Bit Name IOB3 IOB2 IOB1 IOB0 IOA3 IOA2 IOA1 IOA0 Initial Value 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W R/W Description I/O Control B3 to B0 Specify the function of TGRB. For details, see tables 9.13, 9.15, 9.16, 9.17, 9.19, and 9.20. I/O Control A3 to A0 Specify the function of TGRA. For details, see tables 9.21, 9.23, 9.24, 9.25, 9.27, and 9.28.
* TIORL_0, TIORL_3:
Bit 7 6 5 4 3 2 1 0 Bit Name IOD3 IOD2 IOD1 IOD0 IOC3 IOC2 IOC1 IOC0 Initial Value 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W R/W I/O Control C3 to C0 Specify the function of TGRC. For details, see tables 9.22, and 9.26. Description I/O Control D3 to D0 Specify the function of TGRD. For details, see tables 9.14, and 9.18.
Rev.2.00 Jun. 28, 2007 Page 320 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.13 TIORH_0
Description Bit 7 IOB3 0 0 0 0 0 0 0 0 1 1 1 1 Bit 6 IOB2 0 0 0 0 1 1 1 1 0 0 0 1 Bit 5 IOB1 0 0 1 1 0 0 1 1 0 0 1 x Bit 4 IOB0 0 1 0 1 0 1 0 1 0 1 x x Input capture register TGRB_0 Function Output compare register TIOCB0 Pin Function Output disabled Initial output is 0 output 0 output at compare match Initial output is 0 output 1 output at compare match Initial output is 0 output Toggle output at compare match Output disabled Initial output is 1 output 0 output at compare match Initial output is 1 output 1 output at compare match Initial output is 1 output Toggle output at compare match Capture input source is TIOCB0 pin Input capture at rising edge Capture input source is TIOCB0 pin Input capture at falling edge Capture input source is TIOCB0 pin Input capture at both edges Capture input source is channel 1/count clock Input capture at TCNT_1 count-up/count-down* [Legend] X: Don't care Note: When bits TPSC2 to TPSC0 in TCR_1 are set to B'000 and P/1 is used as the TCNT_1 count clock, this setting is invalid and input capture is not generated.
Rev.2.00 Jun. 28, 2007 Page 321 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.14 TIORL_0
Description Bit 7 IOD3 0 0 0 0 0 0 0 0 1 1 1 1 Bit 6 IOD2 0 0 0 0 1 1 1 1 0 0 0 1 Bit 5 IOD1 0 0 1 1 0 0 1 1 0 0 1 X Bit 4 IOD0 0 1 0 1 0 1 0 1 0 1 X X Input capture register*2 TGRD_0 Function Output compare register*2 TIOCD0 Pin Function Output disabled Initial output is 0 output 0 output at compare match Initial output is 0 output 1 output at compare match Initial output is 0 output Toggle output at compare match Output disabled Initial output is 1 output 0 output at compare match Initial output is 1 output 1 output at compare match Initial output is 1 output Toggle output at compare match Capture input source is TIOCD0 pin Input capture at rising edge Capture input source is TIOCD0 pin Input capture at falling edge Capture input source is TIOCD0 pin Input capture at both edges Capture input source is channel 1/count clock Input capture at TCNT_1 count-up/count-down*
1
[Legend] X: Don't care Notes: 1. When bits TPSC2 to TPSC0 in TCR_1 are set to B'000 and P/1 is used as the TCNT_1 count clock, this setting is invalid and input capture is not generated. 2. When the BFB bit in TMDR_0 is set to 1 and TGRD_0 is used as a buffer register, this setting is invalid and input capture/output compare is not generated.
Rev.2.00 Jun. 28, 2007 Page 322 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.15 TIOR_1
Description Bit 7 IOB3 0 0 0 0 0 0 0 0 1 1 1 1 Bit 6 IOB2 0 0 0 0 1 1 1 1 0 0 0 1 Bit 5 IOB1 0 0 1 1 0 0 1 1 0 0 1 X Bit 4 IOB0 0 1 0 1 0 1 0 1 0 1 X X Input capture register TGRB_1 Function Output compare register TIOCB1 Pin Function Output disabled Initial output is 0 output 0 output at compare match Initial output is 0 output 1 output at compare match Initial output is 0 output Toggle output at compare match Output disabled Initial output is 1 output 0 output at compare match Initial output is 1 output 1 output at compare match Initial output is 1 output Toggle output at compare match Capture input source is TIOCB1 pin Input capture at rising edge Capture input source is TIOCB1 pin Input capture at falling edge Capture input source is TIOCB1 pin Input capture at both edges TGRC_0 compare match/input capture Input capture at generation of TGRC_0 compare match/input capture [Legend] X: Don't care
Rev.2.00 Jun. 28, 2007 Page 323 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.16 TIOR_2
Description Bit 7 IOB3 0 0 0 0 0 0 0 0 1 1 1 Bit 6 IOB2 0 0 0 0 1 1 1 1 X X X Bit 5 IOB1 0 0 1 1 0 0 1 1 0 0 1 Bit 4 IOB0 0 1 0 1 0 1 0 1 0 1 X Input capture register TGRB_2 Function Output compare register TIOCB2 Pin Function Output disabled Initial output is 0 output 0 output at compare match Initial output is 0 output 1 output at compare match Initial output is 0 output Toggle output at compare match Output disabled Initial output is 1 output 0 output at compare match Initial output is 1 output 1 output at compare match Initial output is 1 output Toggle output at compare match Capture input source is TIOCB2 pin Input capture at rising edge Capture input source is TIOCB2 pin Input capture at falling edge Capture input source is TIOCB2 pin Input capture at both edges [Legend] X: Don't care
Rev.2.00 Jun. 28, 2007 Page 324 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.17 TIORH_3
Description Bit 7 IOB3 0 0 0 0 0 0 0 0 1 1 1 1 Bit 6 IOB2 0 0 0 0 1 1 1 1 0 0 0 1 Bit 5 IOB1 0 0 1 1 0 0 1 1 0 0 1 x Bit 4 IOB0 0 1 0 1 0 1 0 1 0 1 x x Input capture register TGRB_3 Function Output compare register TIOCB3 Pin Function Output disabled Initial output is 0 output 0 output at compare match Initial output is 0 output 1 output at compare match Initial output is 0 output Toggle output at compare match Output disabled Initial output is 1 output 0 output at compare match Initial output is 1 output 1 output at compare match Initial output is 1 output Toggle output at compare match Capture input source is TIOCB3 pin Input capture at rising edge Capture input source is TIOCB3 pin Input capture at falling edge Capture input source is TIOCB3 pin Input capture at both edges Capture input source is channel 4/count clock Input capture at TCNT_4 count-up/count-down* [Legend] X: Don't care Note: When bits TPSC2 to TPSC0 in TCR_4 are set to B'000 and P/1 is used as the TCNT_4 count clock, this setting is invalid and input capture is not generated.
Rev.2.00 Jun. 28, 2007 Page 325 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.18 TIORL_3
Description Bit 7 IOD3 0 0 0 0 0 0 0 0 1 1 1 1 Bit 6 IOD2 0 0 0 0 1 1 1 1 0 0 0 1 Bit 5 IOD1 0 0 1 1 0 0 1 1 0 0 1 x Bit 4 IOD0 0 1 0 1 0 1 0 1 0 1 x x Input capture register*2 TGRD_3 Function Output compare register*2 TIOCD3 Pin Function Output disabled Initial output is 0 output 0 output at compare match Initial output is 0 output 1 output at compare match Initial output is 0 output Toggle output at compare match Output disabled Initial output is 1 output 0 output at compare match Initial output is 1 output 1 output at compare match Initial output is 1 output Toggle output at compare match Capture input source is TIOCD3 pin Input capture at rising edge Capture input source is TIOCD3 pin Input capture at falling edge Capture input source is TIOCD3 pin Input capture at both edges Capture input source is channel 4/count clock Input capture at TCNT_4 count-up/count-down*
1
[Legend] X: Don't care Notes: 1. When bits TPSC2 to TPSC0 in TCR_4 are set to B'000 and P/1 is used as the TCNT_4 count clock, this setting is invalid and input capture is not generated. 2. When the BFB bit in TMDR_3 is set to 1 and TGRD_3 is used as a buffer register, this setting is invalid and input capture/output compare is not generated.
Rev.2.00 Jun. 28, 2007 Page 326 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.19 TIOR_4
Description Bit 7 IOB3 0 0 0 0 0 0 0 0 1 1 1 1 Bit 6 IOB2 0 0 0 0 1 1 1 1 0 0 0 1 Bit 5 IOB1 0 0 1 1 0 0 1 1 0 0 1 x Bit 4 IOB0 0 1 0 1 0 1 0 1 0 1 x x Input capture register TGRB_4 Function Output compare register TIOCB4 Pin Function Output disabled Initial output is 0 output 0 output at compare match Initial output is 0 output 1 output at compare match Initial output is 0 output Toggle output at compare match Output disabled Initial output is 1 output 0 output at compare match Initial output is 1 output 1 output at compare match Initial output is 1 output Toggle output at compare match Capture input source is TIOCB4 pin Input capture at rising edge Capture input source is TIOCB4 pin Input capture at falling edge Capture input source is TIOCB4 pin Input capture at both edges Capture input source is TGRC_3 compare match/input capture Input capture at generation of TGRC_3 compare match/input capture [Legend] X: Don't care
Rev.2.00 Jun. 28, 2007 Page 327 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.20 TIOR_5
Description Bit 7 IOB3 0 0 0 0 0 0 0 0 1 1 1 Bit 6 IOB2 0 0 0 0 1 1 1 1 x x x Bit 5 IOB1 0 0 1 1 0 0 1 1 0 0 1 Bit 4 IOB0 0 1 0 1 0 1 0 1 0 1 x Input capture register TGRB_5 Function Output compare register TIOCB5 Pin Function Output disabled Initial output is 0 output 0 output at compare match Initial output is 0 output 1 output at compare match Initial output is 0 output Toggle output at compare match Output disabled Initial output is 1 output 0 output at compare match Initial output is 1 output 1 output at compare match Initial output is 1 output Toggle output at compare match Capture input source is TIOCB5 pin Input capture at rising edge Capture input source is TIOCB5 pin Input capture at falling edge Capture input source is TIOCB5 pin Input capture at both edges [Legend] X: Don't care
Rev.2.00 Jun. 28, 2007 Page 328 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.21 TIORH_0
Description Bit 3 IOA3 0 0 0 0 0 0 0 0 1 1 1 1 Bit 2 IOA2 0 0 0 0 1 1 1 1 0 0 0 1 Bit 1 IOA1 0 0 1 1 0 0 1 1 0 0 1 X Bit 0 IOA0 0 1 0 1 0 1 0 1 0 1 X X Input capture register TGRA_0 Function Output compare register TIOCA0 Pin Function Output disabled Initial output is 0 output 0 output at compare match Initial output is 0 output 1 output at compare match Initial output is 0 output Toggle output at compare match Output disabled Initial output is 1 output 0 output at compare match Initial output is 1 output 1 output at compare match Initial output is 1 output Toggle output at compare match Capture input source is TIOCA0 pin Input capture at rising edge Capture input source is TIOCA0 pin Input capture at falling edge Capture input source is TIOCA0 pin Input capture at both edges Capture input source is channel 1/count clock Input capture at TCNT_1 count-up/count-down [Legend] X: Don't care
Rev.2.00 Jun. 28, 2007 Page 329 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.22 TIORL_0
Description Bit 3 IOC3 0 0 0 0 0 0 0 0 1 1 1 1 Bit 2 IOC2 0 0 0 0 1 1 1 1 0 0 0 1 Bit 1 IOC1 0 0 1 1 0 0 1 1 0 0 1 X Bit 0 IOC0 0 1 0 1 0 1 0 1 0 1 X X Input capture register* TGRC_0 Function Output compare register* TIOCC0 Pin Function Output disabled Initial output is 0 output 0 output at compare match Initial output is 0 output 1 output at compare match Initial output is 0 output Toggle output at compare match Output disabled Initial output is 1 output 0 output at compare match Initial output is 1 output 1 output at compare match Initial output is 1 output Toggle output at compare match Capture input source is TIOCC0 pin Input capture at rising edge Capture input source is TIOCC0 pin Input capture at falling edge Capture input source is TIOCC0 pin Input capture at both edges Capture input source is channel 1/count clock Input capture at TCNT_1 count-up/count-down [Legend] X: Don't care Note: 1. When the BFA bit in TMDR_0 is set to 1 and TGRC_0 is used as a buffer register, this setting is invalid and input capture/output compare is not generated.
Rev.2.00 Jun. 28, 2007 Page 330 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.23 TIOR_1
Description Bit 3 IOA3 0 0 0 0 0 0 0 0 1 1 1 1 Bit 2 IOA2 0 0 0 0 1 1 1 1 0 0 0 1 Bit 1 IOA1 0 0 1 1 0 0 1 1 0 0 1 X Bit 0 IOA0 0 1 0 1 0 1 0 1 0 1 X X Input capture register TGRA_1 Function Output compare register TIOCA1 Pin Function Output disabled Initial output is 0 output 0 output at compare match Initial output is 0 output 1 output at compare match Initial output is 0 output Toggle output at compare match Output disabled Initial output is 1 output 0 output at compare match Initial output is 1 output 1 output at compare match Initial output is 1 output Toggle output at compare match Capture input source is TIOCA1 pin Input capture at rising edge Capture input source is TIOCA1 pin Input capture at falling edge Capture input source is TIOCA1 pin Input capture at both edges Capture input source is TGRA_0 compare match/input capture Input capture at generation of channel 0/TGRA_0 compare match/input capture [Legend] X: Don't care
Rev.2.00 Jun. 28, 2007 Page 331 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.24 TIOR_2
Description Bit 3 IOA3 0 0 0 0 0 0 0 0 1 1 1 Bit 2 IOA2 0 0 0 0 1 1 1 1 X X X Bit 1 IOA1 0 0 1 1 0 0 1 1 0 0 1 Bit 0 IOA0 0 1 0 1 0 1 0 1 0 1 X Input capture register TGRA_2 Function Output compare register TIOCA2 Pin Function Output disabled Initial output is 0 output 0 output at compare match Initial output is 0 output 1 output at compare match Initial output is 0 output Toggle output at compare match Output disabled Initial output is 1 output 0 output at compare match Initial output is 1 output 1 output at compare match Initial output is 1 output Toggle output at compare match Capture input source is TIOCA2 pin Input capture at rising edge Capture input source is TIOCA2 pin Input capture at falling edge Capture input source is TIOCA2 pin Input capture at both edges [Legend] X: Don't care
Rev.2.00 Jun. 28, 2007 Page 332 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.25 TIORH_3
Description Bit 3 IOA3 0 0 0 0 0 0 0 0 1 1 1 1 Bit 2 IOA2 0 0 0 0 1 1 1 1 0 0 0 1 Bit 1 IOA1 0 0 1 1 0 0 1 1 0 0 1 X Bit 0 IOA0 0 1 0 1 0 1 0 1 0 1 X X Input capture register TGRA_3 Function Output compare register TIOCA3 Pin Function Output disabled Initial output is 0 output 0 output at compare match Initial output is 0 output 1 output at compare match Initial output is 0 output Toggle output at compare match Output disabled Initial output is 1 output 0 output at compare match Initial output is 1 output 1 output at compare match Initial output is 1 output Toggle output at compare match Capture input source is TIOCA3 pin Input capture at rising edge Capture input source is TIOCA3 pin Input capture at falling edge Capture input source is TIOCA3 pin Input capture at both edges Capture input source is channel 4/count clock Input capture at TCNT_4 count-up/count-down [Legend] X: Don't care
Rev.2.00 Jun. 28, 2007 Page 333 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.26 TIORL_3
Description Bit 3 IOC3 0 0 0 0 0 0 0 0 1 1 1 1 Bit 2 IOC2 0 0 0 0 1 1 1 1 0 0 0 1 Bit 1 IOC1 0 0 1 1 0 0 1 1 0 0 1 X Bit 0 IOC0 0 1 0 1 0 1 0 1 0 1 X X Input capture register* TGRC_3 Function Output compare register* TIOCC3 Pin Function Output disabled Initial output is 0 output 0 output at compare match Initial output is 0 output 1 output at compare match Initial output is 0 output Toggle output at compare match Output disabled Initial output is 1 output 0 output at compare match Initial output is 1 output 1 output at compare match Initial output is 1 output Toggle output at compare match Capture input source is TIOCC3 pin Input capture at rising edge Capture input source is TIOCC3 pin Input capture at falling edge Capture input source is TIOCC3 pin Input capture at both edges Capture input source is channel 4/count clock Input capture at TCNT_4 count-up/count-down [Legend] X: Don't care Note: * When the BFA bit in TMDR_3 is set to 1 and TGRC_3 is used as a buffer register, this setting is invalid and input capture/output compare is not generated.
Rev.2.00 Jun. 28, 2007 Page 334 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.27 TIOR_4
Description Bit 3 IOA3 0 0 0 0 0 0 0 0 1 1 1 1 Bit 2 IOA2 0 0 0 0 1 1 1 1 0 0 0 1 Bit 1 IOA1 0 0 1 1 0 0 1 1 0 0 1 X Bit 0 IOA0 0 1 0 1 0 1 0 1 0 1 X X Input capture register TGRA_4 Function Output compare register TIOCA4 Pin Function Output disabled Initial output is 0 output 0 output at compare match Initial output is 0 output 1 output at compare match Initial output is 0 output Toggle output at compare match Output disabled Initial output is 1 output 0 output at compare match Initial output is 1 output 1 output at compare match Initial output is 1 output Toggle output at compare match Capture input source is TIOCA4 pin Input capture at rising edge Capture input source is TIOCA4 pin Input capture at falling edge Capture input source is TIOCA4 pin Input capture at both edges Capture input source is TGRA_3 compare match/input capture Input capture at generation of TGRA_3 compare match/input capture [Legend] X: Don't care
Rev.2.00 Jun. 28, 2007 Page 335 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Table 9.28 TIOR_5
Description Bit 3 IOA3 0 0 0 0 0 0 0 0 1 1 1 Bit 2 IOA2 0 0 0 0 1 1 1 1 X X X Bit 1 IOA1 0 0 1 1 0 0 1 1 0 0 1 Bit 0 IOA0 0 1 0 1 0 1 0 1 0 1 X Input capture register TGRA_5 Function Output compare register TIOCA5 Pin Function Output disabled Initial output is 0 output 0 output at compare match Initial output is 0 output 1 output at compare match Initial output is 0 output Toggle output at compare match Output disabled Initial output is 1 output 0 output at compare match Initial output is 1 output 1 output at compare match Initial output is 1 output Toggle output at compare match Input capture source is TIOCA5 pin Input capture at rising edge Input capture source is TIOCA5 pin Input capture at falling edge Input capture source is TIOCA5 pin Input capture at both edges [Legend] X: Don't care
Rev.2.00 Jun. 28, 2007 Page 336 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.3.4
Timer Interrupt Enable Register (TIER)
TIER controls enabling or disabling of interrupt requests for each channel. The TPU has six TIER registers, one for each channel.
Bit Bit Name Initial Value R/W 7 TTGE 0 R/W 6 1 R 5 TCIEU 0 R/W 4 TCIEV 0 R/W 3 TGIED 0 R/W 2 TCIEC 0 R/W 1 TGIEB 0 R/W 0 TGIEA 0 R/W
Bit 7
Bit Name TTGE
Initial value 0
R/W R/W
Description A/D Conversion Start Request Enable Enables/disables generation of A/D conversion start requests by TGRA input capture/compare match. 0: A/D conversion start request generation disabled 1: A/D conversion start request generation enabled
6 5
TCIEU
1 0
R R/W
Reserved This is a read-only bit and cannot be modified. Underflow Interrupt Enable Enables/disables interrupt requests (TCIU) by the TCFU flag when the TCFU flag in TSR is set to 1 in channels 1, 2, 4, and 5. In channels 0 and 3, bit 5 is reserved. It is always read as 0 and cannot be modified. 0: Interrupt requests (TCIU) by TCFU disabled 1: Interrupt requests (TCIU) by TCFU enabled
4
TCIEV
0
R/W
Overflow Interrupt Enable Enables/disables interrupt requests (TCIV) by the TCFV flag when the TCFV flag in TSR is set to 1. 0: Interrupt requests (TCIV) by TCFV disabled 1: Interrupt requests (TCIV) by TCFV enabled
Rev.2.00 Jun. 28, 2007 Page 337 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Bit 3
Bit Name TGIED
Initial value 0
R/W R/W
Description TGR Interrupt Enable D Enables/disables interrupt requests (TGID) by the TGFD bit when the TGFD bit in TSR is set to 1 in channels 0 and 3. In channels 1, 2, 4, and 5, bit 3 is reserved. It is always read as 0 and cannot be modified. 0: Interrupt requests (TGID) by TGFD bit disabled 1: Interrupt requests (TGID) by TGFD bit enabled
2
TGIEC
0
R/W
TGR Interrupt Enable C Enables/disables interrupt requests (TGIC) by the TGFC bit when the TGFC bit in TSR is set to 1 in channels 0 and 3. In channels 1, 2, 4, and 5, bit 2 is reserved. It is always read as 0 and cannot be modified. 0: Interrupt requests (TGIC) by TGFC bit disabled 1: Interrupt requests (TGIC) by TGFC bit enabled
1
TGIEB
0
R/W
TGR Interrupt Enable B Enables/disables interrupt requests (TGIB) by the TGFB bit when the TGFB bit in TSR is set to 1. 0: Interrupt requests (TGIB) by TGFB bit disabled 1: Interrupt requests (TGIB) by TGFB bit enabled
0
TGIEA
0
R/W
TGR Interrupt Enable A Enables/disables interrupt requests (TGIA) by the TGFA bit when the TGFA bit in TSR is set to 1. 0: Interrupt requests (TGIA) by TGFA bit disabled 1: Interrupt requests (TGIA) by TGFA bit enabled
Rev.2.00 Jun. 28, 2007 Page 338 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.3.5
Timer Status Register (TSR)
TSR indicates the status of each channel. The TPU has six TSR registers, one for each channel.
Bit Bit Name Initial Value R/W 7 TCFD 1 R 6 1 R 5 TCFU 0 R/(W)* 4 TCFV 0 R/(W)* 3 TGFD 0 R/(W)* 2 TGFC 0 R/(W)* 1 TGFB 0 R/(W)* 0 TGFA 0 R/(W)*
Note: * Only 0 can be written to bits 5 to 0, to clear flags.
Bit 7
Bit Name TCFD
Initial value 1
R/W R
Description Count Direction Flag Status flag that shows the direction in which TCNT counts in channels 1, 2, 4, and 5. In channels 0 and 3, bit 7 is reserved. It is always read as 1 and cannot be modified. 0: TCNT counts down 1: TCNT counts up
6 5
TCFU
1 0
R
Reserved This is a read-only bit and cannot be modified.
R/(W)* Underflow Flag Status flag that indicates that a TCNT underflow has occurred when channels 1, 2, 4, and 5 are set to phase counting mode. In channels 0 and 3, bit 5 is reserved. It is always read as 0 and cannot be modified. [Setting condition] When the TCNT value underflows (changes from H'0000 to H'FFFF) [Clearing condition] When a 0 is written to TCFU after reading TCFU = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.)
Rev.2.00 Jun. 28, 2007 Page 339 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Bit 4
Bit Name TCFV
Initial value 0
R/W
Description
R/(W)* Overflow Flag Status flag that indicates that a TCNT overflow has occurred. [Setting condition] When the TCNT value overflows (changes from H'FFFF to H'0000) [Clearing condition] When a 0 is written to TCFV after reading TCFV = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.)
3
TGFD
0
R/(W)* Input Capture/Output Compare Flag D Status flag that indicates the occurrence of TGRD input capture or compare match in channels 0 and 3. In channels 1, 2, 4, and 5, bit 3 is reserved. It is always read as 0 and cannot be modified. [Setting conditions] * * When TCNT = TGRD while TGRD is functioning as output compare register When TCNT value is transferred to TGRD by input capture signal while TGRD is functioning as input capture register When DTC is activated by a TGID interrupt while the DISEL bit in MRB of DTC is 0 When 0 is written to TGFD after reading TGFD = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.)
[Clearing conditions] * *
Rev.2.00 Jun. 28, 2007 Page 340 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Bit 2
Bit Name TGFC
Initial value 0
R/W
Description
R/(W)* Input Capture/Output Compare Flag C Status flag that indicates the occurrence of TGRC input capture or compare match in channels 0 and 3. In channels 1, 2, 4, and 5, bit 2 is reserved. It is always read as 0 and cannot be modified. [Setting conditions] * * When TCNT = TGRC while TGRC is functioning as output compare register When TCNT value is transferred to TGRC by input capture signal while TGRC is functioning as input capture register When DTC is activated by a TGIC interrupt while the DISEL bit in MRB of DTC is 0 When 0 is written to TGFC after reading TGFC = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.)
[Clearing conditions] * *
1
TGFB
0
R/(W)* Input Capture/Output Compare Flag B Status flag that indicates the occurrence of TGRB input capture or compare match. [Setting conditions] * * When TCNT = TGRB while TGRB is functioning as output compare register When TCNT value is transferred to TGRB by input capture signal while TGRB is functioning as input capture register When DTC is activated by a TGIB interrupt while the DISEL bit in MRB of DTC is 0 When 0 is written to TGFB after reading TGFB = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.)
[Clearing conditions] * *
Rev.2.00 Jun. 28, 2007 Page 341 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Bit 0
Bit Name TGFA
Initial value 0
R/W
Description
R/(W)* Input Capture/Output Compare Flag A Status flag that indicates the occurrence of TGRA input capture or compare match. [Setting conditions] * * When TCNT = TGRA while TGRA is functioning as output compare register When TCNT value is transferred to TGRA by input capture signal while TGRA is functioning as input capture register When DTC is activated by a TGIA interrupt while the DISEL bit in MRB of DTC is 0 When 0 is written to TGFA after reading TGFA = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.)
[Clearing conditions] * *
Note:
*
Only 0 can be written to clear the flag.
Rev.2.00 Jun. 28, 2007 Page 342 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.3.6
Timer Counter (TCNT)
TCNT is a 16-bit readable/writable counter. The TPU has six TCNT counters, one for each channel. TCNT is initialized to H'0000 by a reset or in hardware standby mode. TCNT cannot be accessed in 8-bit units. TCNT must always be accessed in 16-bit units.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 0 R/W 0 R/W 0 R/W 0 R/W 0 R/W 0 R/W 0 R/W 0 R/W 0 R/W 7 0 R/W 6 0 R/W 5 0 R/W 4 0 R/W 3 0 R/W 2 0 R/W 1 0 R/W 0 15 14 13 12 11 10 9 8
9.3.7
Timer General Register (TGR)
TGR is a 16-bit readable/writable register with a dual function as output compare and input capture registers. The TPU has 16 TGR registers, four each for channels 0 and 3 and two each for channels 1, 2, 4, and 5. TGRC and TGRD for channels 0 and 3 can also be designated for operation as buffer registers. The TGR registers cannot be accessed in 8-bit units; they must always be accessed in 16-bit units. TGR and buffer register combinations during buffer operations are TGRA-TGRC and TGRB-TGRD.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 1 R/W 1 R/W 1 R/W 1 R/W 1 R/W 1 R/W 1 R/W 1 R/W 1 R/W 7 1 R/W 6 1 R/W 5 1 R/W 4 1 R/W 3 1 R/W 2 1 R/W 1 1 R/W 0 15 14 13 12 11 10 9 8
Rev.2.00 Jun. 28, 2007 Page 343 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.3.8
Timer Start Register (TSTR)
TSTR starts or stops operation for channels 0 to 5. When setting the operating mode in TMDR or setting the count clock in TCR, first stop the TCNT counter.
Bit Bit Name Initial Value R/W 7 0 R/W 6 0 R/W 5 CST5 0 R/W 4 CST4 0 R/W 3 CST3 0 R/W 2 CST2 0 R/W 1 CST1 0 R/W 0 CST0 0 R/W
Bit 7, 6
Bit Name
Initial value All 0
R/W R/W
Description Reserved These bits are always read as 0. The write value should always be 0.
5 4 3 2 1 0
CST5 CST4 CST3 CST2 CST1 CST0
0 0 0 0 0 0
R/W R/W R/W R/W R/W R/W
Counter Start 5 to 0 These bits select operation or stoppage for TCNT. If 0 is written to the CST bit during operation with the TIOC pin designated for output, the counter stops but the TIOC pin output compare output level is retained. If TIOR is written to when the CST bit is cleared to 0, the pin output level will be changed to the set initial output value. 0: TCNT_5 to TCNT_0 count operation is stopped 1: TCNT_5 to TCNT_0 performs count operation
Rev.2.00 Jun. 28, 2007 Page 344 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.3.9
Timer Synchronous Register (TSYR)
TSYR selects independent operation or synchronous operation for the TCNT counters of channels 0 to 5. A channel performs synchronous operation when the corresponding bit in TSYR is set to 1.
Bit Bit Name Initial Value R/W 7 0 R/W 6 0 R/W 5 SYNC5 0 R/W 4 SYNC4 0 R/W 3 SYNC3 0 R/W 2 SYNC2 0 R/W 1 SYNC1 0 R/W 0 SYNC0 0 R/W
Bit 7, 6
Bit Name
Initial value All 0
R/W R/W
Description Reserved These bits are always read as 0. The write value should always be 0.
5 4 3 2 1 0
SYNC5 SYNC4 SYNC3 SYNC2 SYNC1 SYNC0
0 0 0 0 0 0
R/W R/W R/W R/W R/W R/W
Timer Synchronization 5 to 0 These bits select whether operation is independent of or synchronized with other channels. When synchronous operation is selected, synchronous presetting of multiple channels, and synchronous clearing through counter clearing on another channel are possible. To set synchronous operation, the SYNC bits for at least two channels must be set to 1. To set synchronous clearing, in addition to the SYNC bit, the TCNT clearing source must also be set by means of bits CCLR2 to CCLR0 in TCR. 0: TCNT_5 to TCNT_0 operate independently (TCNT presetting/clearing is unrelated to other channels) 1: TCNT_5 to TCNT_0 perform synchronous operation (TCNT synchronous presetting/synchronous clearing is possible)
Rev.2.00 Jun. 28, 2007 Page 345 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.4
9.4.1
Operation
Basic Functions
Each channel has a TCNT and TGR register. TCNT performs up-counting, and is also capable of free-running operation, periodic counting, and external event counting. Each TGR can be used as an input capture register or output compare register. (1) Counter Operation
When one of bits CST0 to CST5 is set to 1 in TSTR, the TCNT counter for the corresponding channel starts counting. TCNT can operate as a free-running counter, periodic counter, and so on. (a) Example of count operation setting procedure
Figure 9.2 shows an example of the count operation setting procedure.
Operation selection
Select counter clock
[1]
[1] Select the counter clock with bits TPSC2 to TPSC0 in TCR. At the same time, select the input clock edge with bits CKEG1 and CKEG0 in TCR. [2] For periodic counter operation, select the TGR to be used as the TCNT clearing source with bits CCLR2 to CCLR0 in TCR. [3] Designate the TGR selected in [2] as an output compare register by means of TIOR. [4] Set the periodic counter cycle in the TGR selected in [2]. [5] Set the CST bit in TSTR to 1 to start the counter operation.
Periodic counter
Free-running counter
Select counter clearing source
[2]
Select output compare register
[3]
Set period
[4]
Start count
[5]
Start count
[5]
Figure 9.2 Example of Counter Operation Setting Procedure
Rev.2.00 Jun. 28, 2007 Page 346 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(b)
Free-running count operation and periodic count operation
Immediately after a reset, the TPU's TCNT counters are all designated as free-running counters. When the relevant bit in TSTR is set to 1 the corresponding TCNT counter starts up-count operation as a free-running counter. When TCNT overflows (changes from H'FFFF to H'0000), the TCFV bit in TSR is set to 1. If the value of the corresponding TCIEV bit in TIER is 1 at this point, the TPU requests an interrupt. After overflow, TCNT starts counting up again from H'0000. Figure 9.3 illustrates free-running counter operation.
TCNT value H'FFFF
H'0000
Time
CST bit
TCFV
Figure 9.3 Free-Running Counter Operation When compare match is selected as the TCNT clearing source, the TCNT counter for the relevant channel performs periodic count operation. The TGR register for setting the period is designated as an output compare register, and counter clearing by compare match is selected by means of bits CCLR2 to CCLR0 in TCR. After the settings have been made, TCNT starts count-up operation as a periodic counter when the corresponding bit in TSTR is set to 1. When the count value matches the value in TGR, the TGF bit in TSR is set to 1 and TCNT is cleared to H'0000. If the value of the corresponding TGIE bit in TIER is 1 at this point, the TPU requests an interrupt. After a compare match, TCNT starts counting up again from H'0000.
Rev.2.00 Jun. 28, 2007 Page 347 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Figure 9.4 illustrates periodic counter operation.
TCNT value TGR
Counter cleared by TGR compare match
H'0000
Time
CST bit Flag cleared by software or DTC activation TGF
Figure 9.4 Periodic Counter Operation (2) Waveform Output by Compare Match
The TPU can perform 0, 1, or toggle output from the corresponding output pin using a compare match. (a) Example of setting procedure for waveform output by compare match
Figure 9.5 shows an example of the setting procedure for waveform output by a compare match.
Output selection
Select waveform output mode
[1]
[1] Select initial value from 0-output or 1-output, and compare match output value from 0-output, 1-output, or toggle-output, by means of TIOR. The set initial value is output on the TIOC pin until the first compare match occurs. [2] Set the timing for compare match generation in TGR. [3] Set the CST bit in TSTR to 1 to start the count operation.
Set output timing
[2]
Start count
[3]

Figure 9.5 Example of Setting Procedure for Waveform Output by Compare Match
Rev.2.00 Jun. 28, 2007 Page 348 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(b)
Examples of waveform output operation
Figure 9.6 shows an example of 0-output and 1-output. In this example, TCNT has been designated as a free-running counter, and settings have been made so that 1 is output by compare match A, and 0 is output by compare match B. When the set level and the pin level match, the pin level does not change.
TCNT value H'FFFF TGRA TGRB H'0000 No change TIOCA TIOCB No change No change No change 1-output 0-output Time
Figure 9.6 Example of 0-Output/1-Output Operation Figure 9.7 shows an example of toggle output. In this example, TCNT has been designated as a periodic counter (with counter clearing performed by compare match B), and settings have been made so that output is toggled by both compare match A and compare match B.
TCNT value Counter cleared by TGRB compare match H'FFFF TGRB TGRA H'0000 TIOCB TIOCA Time Toggle-output Toggle-output
Figure 9.7 Example of Toggle Output Operation
Rev.2.00 Jun. 28, 2007 Page 349 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(3)
Input Capture Function
The TCNT value can be transferred to TGR on detection of the TIOC pin input edge. Rising edge, falling edge, or both edges can be selected as the detection edge. For channels 0, 1, 3, and 4, it is also possible to specify another channel's counter input clock or compare match signal as the input capture source. Note: When another channel's counter input clock is used as the input capture input for channels 0 and 3, P/1 should not be selected as the counter input clock used for input capture input. Input capture will not be generated if P/1 is selected. (a) Example of setting procedure for input capture operation
Figure 9.8 shows an example of the setting procedure for input capture operation.
[1] Designate TGR as an input capture register by means of TIOR, and select the input capture source and input signal edge (rising edge, falling edge, or both edges). [2] Set the CST bit in TSTR to 1 to start the count operation.
Input selection
Select input capture input
[1]
Start count
[2]

Figure 9.8 Example of Setting Procedure for Input Capture Operation
Rev.2.00 Jun. 28, 2007 Page 350 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(b)
Example of input capture operation
Figure 9.9 shows an example of input capture operation. In this example, both rising and falling edges have been selected as the TIOCA pin input capture input edge, falling edge has been selected as the TIOCB pin input capture input edge, and counter clearing by TGRB input capture has been designated for TCNT.
Counter cleared by TIOCB input (falling edge)
TCNT value H'0180 H'0160
H'0010 H'0005 H'0000 Time
TIOCA
TGRA
H'0005
H'0160
H'0010
TIOCB TGRB H'0180
Figure 9.9 Example of Input Capture Operation
Rev.2.00 Jun. 28, 2007 Page 351 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.4.2
Synchronous Operation
In synchronous operation, the values in multiple TCNT counters can be rewritten simultaneously (synchronous presetting). Also, multiple TCNT counters can be cleared simultaneously (synchronous clearing) by making the appropriate setting in TCR. Synchronous operation enables TGR to be incremented with respect to a single time base. Channels 0 to 5 can all be designated for synchronous operation. (1) Example of Synchronous Operation Setting Procedure
Figure 9.10 shows an example of the synchronous operation setting procedure.
Synchronous operation selection Set synchronous operation
[1]
Synchronous presetting
Synchronous clearing
Set TCNT
[2]
Clearing source generation channel? Yes Select counter clearing source
No
[3]
Set synchronous counter clearing
[4]
Start count
[5]
Start count
[5]



[1] Set the SYNC bits in TSYR corresponding to the channels to be designated for synchronous operation to 1. [2] When the TCNT counter of any of the channels designated for synchronous operation is written to, the same value is simultaneously written to the other TCNT counters. [3] Use bits CCLR2 to CCLR0 in TCR to specify TCNT clearing by input capture/output compare, etc. [4] Use bits CCLR2 to CCLR0 in TCR to designate synchronous clearing for the counter clearing source. [5] Set the CST bits in TSTR for the relevant channels to 1, to start the count operation.
Figure 9.10 Example of Synchronous Operation Setting Procedure
Rev.2.00 Jun. 28, 2007 Page 352 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(2)
Example of Synchronous Operation
Figure 9.11 shows an example of synchronous operation. In this example, synchronous operation and PWM mode 1 have been designated for channels 0 to 2, TGRB_0 compare match has been set as the channel 0 counter clearing source, and synchronous clearing has been set for the channel 1 and 2 counter clearing source. Three-phase PWM waveforms are output from pins TIOCA0, TIOCA1, and TIOCA2. At this time, synchronous presetting and synchronous clearing by TGRB_0 compare match are performed for channel 0 to 2 TCNT counters, and the data set in TGRB_0 is used as the PWM cycle. For details on PWM modes, see section 9.4.5, PWM Modes.
TCNT_0 to TCNT_2 values TGRB_0 TGRB_1 TGRA_0 TGRB_2 TGRA_1 TGRA_2 H'0000 TIOCA_0 TIOCA_1 TIOCA_2 Time Synchronous clearing by TGRB_0 compare match
Figure 9.11 Example of Synchronous Operation
Rev.2.00 Jun. 28, 2007 Page 353 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.4.3
Buffer Operation
Buffer operation, provided for channels 0 and 3, enables TGRC and TGRD to be used as buffer registers. Buffer operation differs depending on whether TGR has been designated as an input capture register or a compare match register. Table 9.29 shows the register combinations used in buffer operation. Table 9.29 Register Combinations in Buffer Operation
Channel 0 Timer General Register TGRA_0 TGRB_0 3 TGRA_3 TGRB_3 Buffer Register TGRC_0 TGRD_0 TGRC_3 TGRD_3
* When TGR is an output compare register When a compare match occurs, the value in the buffer register for the corresponding channel is transferred to the timer general register. This operation is illustrated in figure 9.12.
Compare match signal
Buffer register
Timer general register
Comparator
TCNT
Figure 9.12 Compare Match Buffer Operation
Rev.2.00 Jun. 28, 2007 Page 354 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
* When TGR is an input capture register When input capture occurs, the value in TCNT is transferred to TGR and the value previously held in TGR is transferred to the buffer register. This operation is illustrated in figure 9.13.
Input capture signal Timer general register
Buffer register
TCNT
Figure 9.13 Input Capture Buffer Operation (1) Example of Buffer Operation Setting Procedure
Figure 9.14 shows an example of the buffer operation setting procedure.
[1] Designate TGR as an input capture register or output compare register by means of TIOR. [1] [2] Designate TGR for buffer operation with bits BFA and BFB in TMDR. [3] Set the CST bit in TSTR to 1 to start the count operation.
Buffer operation
Select TGR function
Set buffer operation
[2]
Start count
[3]

Figure 9.14 Example of Buffer Operation Setting Procedure
Rev.2.00 Jun. 28, 2007 Page 355 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(2) (a)
Examples of Buffer Operation When TGR is an output compare register
Figure 9.15 shows an operation example in which PWM mode 1 has been designated for channel 0, and buffer operation has been designated for TGRA and TGRC. The settings used in this example are TCNT clearing by compare match B, 1 output at compare match A, and 0 output at compare match B. As buffer operation has been set, when compare match A occurs, the output changes and the value in buffer register TGRC is simultaneously transferred to timer general register TGRA. This operation is repeated each time compare match A occurs. For details on PWM modes, see section 9.4.5, PWM Modes.
TCNT value
TGRB_0 H'0200 TGRA_0 H'0000 TGRC_0 H'0200 Transfer TGRA_0 H'0200 H'0450
H'0450
H'0520
Time H'0520
H'0450
TIOCA
Figure 9.15 Example of Buffer Operation (1) (b) When TGR is an input capture register
Figure 9.16 shows an operation example in which TGRA has been designated as an input capture register, and buffer operation has been designated for TGRA and TGRC. Counter clearing by TGRA input capture has been set for TCNT, and both rising and falling edges have been selected as the TIOCA pin input capture input edge. As buffer operation has been set, when the TCNT value is stored in TGRA upon occurrence of input capture A, the value previously stored in TGRA is simultaneously transferred to TGRC.
Rev.2.00 Jun. 28, 2007 Page 356 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
TCNT value
H'0F07 H'09FB H'0532 H'0000 Time
TIOCA
TGRA
H'0532
H'0F07
H'09FB
TGRC
H'0532
H'0F07
Figure 9.16 Example of Buffer Operation (2) 9.4.4 Cascaded Operation
In cascaded operation, two 16-bit counters for different channels are used together as a 32-bit counter. This function works by counting the channel 1 (channel 4) counter clock at overflow/underflow of TCNT_2 (TCNT_5) as set in bits TPSC2 to TPSC0 in TCR. Underflow occurs only when the lower 16-bit TCNT is in phase-counting mode. Table 9.30 shows the register combinations used in cascaded operation. Note: When phase counting mode is set for channel 1 or 4, the counter clock setting is invalid and the counter operates independently in phase counting mode. Table 9.30 Cascaded Combinations
Combination Channels 1 and 2 Channels 4 and 5 Upper 16 Bits TCNT_1 TCNT_4 Lower 16 Bits TCNT_2 TCNT_5
Rev.2.00 Jun. 28, 2007 Page 357 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(1)
Example of Cascaded Operation Setting Procedure
Figure 9.17 shows an example of the setting procedure for cascaded operation.
Cascaded operation
[1] Set bits TPSC2 to TPSC0 in the channel 1 (channel 4) TCR to B'1111 to select TCNT_2 (TCNT_5) overflow/underflow counting. [1] [2] Set the CST bit in TSTR for the upper and lower channels to 1 to start the count operation.
Set cascading
Start count
[2]

Figure 9.17 Example of Cascaded Operation Setting Procedure (2) Examples of Cascaded Operation
Figure 9.18 illustrates the operation when counting upon TCNT_2 overflow/underflow has been set for TCNT_1, TGRA_1 and TGRA_2 have been designated as input capture registers, and the TIOC pin rising edge has been selected. When a rising edge is input to the TIOCA1 and TIOCA2 pins simultaneously, the upper 16 bits of the 32-bit data are transferred to TGRA_1, and the lower 16 bits to TGRA_2.
TCNT_1 clock TCNT_1 TCNT_2 clock TCNT_2 TIOCA1, TIOCA2 TGRA_1 TGRA_2 H'03A2 H'0000 H'FFFF H'0000 H'0001 H'03A1 H'03A2
Figure 9.18 Example of Cascaded Operation (1)
Rev.2.00 Jun. 28, 2007 Page 358 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Figure 9.19 illustrates the operation when counting upon TCNT_2 overflow/underflow has been set for TCNT_1, and phase counting mode has been designated for channel 2. TCNT_1 is incremented by TCNT_2 overflow and decremented by TCNT_2 underflow.
TCLKC
TCLKD TCNT_2 TCNT_1 FFFD FFFE FFFF 0000 0001 0002 0001 0001 0000 FFFF 0000
0000
Figure 9.19 Example of Cascaded Operation (2) 9.4.5 PWM Modes
In PWM mode, PWM waveforms are output from the output pins. 0-, 1-, or toggle-output can be selected as the output level in response to compare match of each TGR. Settings of TGR registers can output a PWM waveform in the range of 0% to 100% duty cycle. Designating TGR compare match as the counter clearing source enables the cycle to be set in that register. All channels can be designated for PWM mode independently. Synchronous operation is also possible. There are two PWM modes, as described below. 1. PWM mode 1 PWM output is generated from the TIOCA and TIOCC pins by pairing TGRA with TGRB and TGRC with TGRD. The outputs specified by bits IOA3 to IOA0 and IOC3 to IOC0 in TIOR are output from the TIOCA and TIOCC pins at compare matches A and C, respectively. The outputs specified by bits IOB3 to IOB0 and IOD3 to IOD0 in TIOR are output at compare matches B and D, respectively. The initial output value is the value set in TGRA or TGRC. If the set values of paired TGRs are identical, the output value does not change when a compare match occurs. In PWM mode 1, a maximum 8-phase PWM output is possible.
Rev.2.00 Jun. 28, 2007 Page 359 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
2. PWM mode 2 PWM output is generated using one TGR as the cycle register and the others as duty cycle registers. The output specified in TIOR is performed by means of compare matches. Upon counter clearing by a cycle register compare match, the output value of each pin is the initial value set in TIOR. If the set values of the cycle and duty cycle registers are identical, the output value does not change when a compare match occurs. In PWM mode 2, a maximum 15-phase PWM output is possible by combined use with synchronous operation. The correspondence between PWM output pins and registers is shown in table 9.31. Table 9.31 PWM Output Registers and Output Pins
Output Pins Channel 0 Registers TGRA_0 TGRB_0 TGRC_0 TGRD_0 1 TGRA_1 TGRB_1 2 TGRA_2 TGRB_2 3 TGRA_3 TGRB_3 TGRC_3 TGRD_3 4 TGRA_4 TGRB_4 5 TGRA_5 TGRB_5 TIOCA5 TIOCA4 TIOCC3 TIOCA3 TIOCA2 TIOCA1 TIOCC0 PWM Mode 1 TIOCA0 PWM Mode 2 TIOCA0 TIOCB0 TIOCC0 TIOCD0 TIOCA1 TIOCB1 TIOCA2 TIOCB2 TIOCA3 TIOCB3 TIOCC3 TIOCD3 TIOCA4 TIOCB4 TIOCA5 TIOCB5
Note: In PWM mode 2, PWM output is not possible for the TGR register in which the cycle is set.
Rev.2.00 Jun. 28, 2007 Page 360 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(1)
Example of PWM Mode Setting Procedure
Figure 9.20 shows an example of the PWM mode setting procedure.
PWM mode
[1] Select the counter clock with bits TPSC2 to TPSC0 in TCR. At the same time, select the [1] input clock edge with bits CKEG1 and CKEG0 in TCR. [2] Use bits CCLR2 to CCLR0 in TCR to select the TGR to be used as the TCNT clearing source. [3] Use TIOR to designate TGR as an output compare register, and select the initial value and output value. [4] Set the cycle in TGR selected in [2], and set the duty in the other TGRs.
Select counter clock
Select counter clearing source
[2]
Select waveform output level
[3]
Set TGR
[4]
Set PWM mode
[5]
[5] Select the PWM mode with bits MD3 to MD0 in TMDR. [6] Set the CST bit in TSTR to 1 to start the count operation.
Start count
[6]

Figure 9.20 Example of PWM Mode Setting Procedure (2) Examples of PWM Mode Operation
Figure 9.21 shows an example of PWM mode 1 operation. In this example, TGRA compare match is set as the TCNT clearing source, 0 is set for the TGRA initial output value and output value, and 1 is set as the TGRB output value. In this case, the value set in TGRA is used as the cycle, and the value set in TGRB register as the duty cycle.
Rev.2.00 Jun. 28, 2007 Page 361 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
TCNT value TGRA Counter cleared by TGRA compare match
TGRB H'0000 TIOCA Time
Figure 9.21 Example of PWM Mode Operation (1) Figure 9.22 shows an example of PWM mode 2 operation. In this example, synchronous operation is designated for channels 0 and 1, TGRB_1 compare match is set as the TCNT clearing source, and 0 is set for the initial output value and 1 for the output value of the other TGR registers (TGRA_0 to TGRD_0, TGRA_1), to output a 5-phase PWM waveform. In this case, the value set in TGRB_1 is used as the cycle, and the values set in the other TGRs as the duty cycle.
TCNT value TGRB_1 TGRA_1 TGRD_0 TGRC_0 TGRB_0 TGRA_0 H'0000 Time TIOCA0
Counter cleared by TGRB_1 compare match
TIOCB0
TIOCC0
TIOCD0
TIOCA1
Figure 9.22 Example of PWM Mode Operation (2)
Rev.2.00 Jun. 28, 2007 Page 362 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Figure 9.23 shows examples of PWM waveform output with 0% duty cycle and 100% duty cycle in PWM mode.
TCNT value TGRB changed TGRA
TGRB H'0000 TIOCA
TGRB changed
TGRB changed Time
0% duty
TCNT value TGRB changed TGRA TGRB changed TGRB H'0000 TIOCA 100% duty TGRB changed Time Output does not change when compare matches in cycle register and duty register occur simultaneously
TCNT value TGRB changed TGRA
Output does not change when compare matches in cycle register and duty register occur simultaneously
TGRB changed
TGRB H'0000 TIOCA 100% duty 0% duty
TGRB changed Time
Figure 9.23 Example of PWM Mode Operation (3)
Rev.2.00 Jun. 28, 2007 Page 363 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.4.6
Phase Counting Mode
In phase counting mode, the phase difference between two external clock inputs is detected and TCNT is incremented/decremented accordingly. This mode can be set for channels 1, 2, 4, and 5. When phase counting mode is set, an external clock is selected as the counter input clock and TCNT operates as an up/down-counter regardless of the setting of bits TPSC2 to TPSC0 and bits CKEG1 and CKEG0 in TCR. However, the functions of bits CCLR1 and CCLR0 in TCR, and of TIOR, TIER, and TGR are valid, and input capture/compare match and interrupt functions can be used. This can be used for two-phase encoder pulse input. When overflow occurs while TCNT is counting up, the TCFV flag in TSR is set; when underflow occurs while TCNT is counting down, the TCFU flag is set. The TCFD bit in TSR is the count direction flag. Reading the TCFD flag provides an indication of whether TCNT is counting up or down. Table 9.32 shows the correspondence between external clock pins and channels. Table 9.32 Clock Input Pins in Phase Counting Mode
External Clock Pins Channels When channel 1 or 5 is set to phase counting mode When channel 2 or 4 is set to phase counting mode A-Phase TCLKA TCLKC B-Phase TCLKB TCLKD
(1)
Example of Phase Counting Mode Setting Procedure
Figure 9.24 shows an example of the phase counting mode setting procedure.
Phase counting mode Select phase counting mode Start count [1] [2]
[1] Select phase counting mode with bits MD3 to MD0 in TMDR. [2] Set the CST bit in TSTR to 1 to start the count operation.

Figure 9.24 Example of Phase Counting Mode Setting Procedure
Rev.2.00 Jun. 28, 2007 Page 364 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(2)
Examples of Phase Counting Mode Operation
In phase counting mode, TCNT counts up or down according to the phase difference between two external clocks. There are four modes, according to the count conditions. (a) Phase counting mode 1
Figure 9.25 shows an example of phase counting mode 1 operation, and table 9.33 summarizes the TCNT up/down-count conditions.
TCLKA (channels 1 and 5) TCLKC (channels 2 and 4) TCLKB (channels 1 and 5) TCLKD (channels 2 and 4) TCNT value
Up-count
Down-count
Time
Figure 9.25 Example of Phase Counting Mode 1 Operation Table 9.33 Up/Down-Count Conditions in Phase Counting Mode 1
TCLKA (Channels 1 and 5) TCLKC (Channels 2 and 4) High level Low level Low level High level High level Low level High level Low level [Legend] : Rising edge : Falling edge Down-count TCLKB (Channels 1 and 5) TCLKD (Channels 2 and 4) Operation Up-count
Rev.2.00 Jun. 28, 2007 Page 365 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(b)
Phase counting mode 2
Figure 9.26 shows an example of phase counting mode 2 operation, and table 9.34 summarizes the TCNT up/down-count conditions.
TCLKA (channels 1 and 5) TCLKC (channels 2 and 4) TCLKB (channels 1 and 5) TCLKD (channels 2 and 4) TCNT value Up-count Down-count
Time
Figure 9.26 Example of Phase Counting Mode 2 Operation Table 9.34 Up/Down-Count Conditions in Phase Counting Mode 2
TCLKA (Channels 1 and 5) TCLKC (Channels 2 and 4) High level Low level Low level High level High level Low level High level Low level [Legend] : Rising edge : Falling edge TCLKB (Channels 1 and 5) TCLKD (Channels 2 and 4) Operation Don't care Don't care Don't care Up-count Don't care Don't care Don't care Down-count
Rev.2.00 Jun. 28, 2007 Page 366 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(c)
Phase counting mode 3
Figure 9.27 shows an example of phase counting mode 3 operation, and table 9.35 summarizes the TCNT up/down-count conditions.
TCLKA (channels 1 and 5) TCLKC (channels 2 and 4) TCLKB (channels 1 and 5) TCLKD (channels 2 and 4) TCNT value
Up-count
Down-count
Time
Figure 9.27 Example of Phase Counting Mode 3 Operation Table 9.35 Up/Down-Count Conditions in Phase Counting Mode 3
TCLKB (Channels 1 and 5) TCLKD (Channels 2 and 4) Operation Don't care Don't care Low level High level High level Low level High level Low level [Legend] : Rising edge : Falling edge Don't care Up-count Down-count Don't care Don't care Don't care
TCLKA (Channels 1 and 5) TCLKC (Channels 2 and 4) High level Low level
Rev.2.00 Jun. 28, 2007 Page 367 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(d)
Phase counting mode 4
Figure 9.28 shows an example of phase counting mode 4 operation, and table 9.36 summarizes the TCNT up/down-count conditions.
TCLKA (channels 1 and 5) TCLKC (channels 2 and 4) TCLKB (channels 1 and 5) TCLKD (channels 2 and 4) TCNT value
Up-count
Down-count
Time
Figure 9.28 Example of Phase Counting Mode 4 Operation Table 9.36 Up/Down-Count Conditions in Phase Counting Mode 4
TCLKA (Channels 1 and 5) TCLKC (Channels 2 and 4) High level Low level Low level High level High level Low level High level Low level [Legend] : Rising edge : Falling edge Don't care Down-count Don't care TCLKB (Channels 1 and 5) TCLKD (Channels 2 and 4) Operation Up-count
Rev.2.00 Jun. 28, 2007 Page 368 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(3)
Phase Counting Mode Application Example
Figure 9.29 shows an example in which phase counting mode is designated for channel 1, and channel 1 is coupled with channel 0 to input servo motor 2-phase encoder pulses in order to detect the position or speed. Channel 1 is set to phase counting mode 1, and the encoder pulse A-phase and B-phase are input to TCLKA and TCLKB. Channel 0 operates with TCNT counter clearing by TGRC_0 compare match; TGRA_0 and TGRC_0 are used for the compare match function and are set with the speed control cycle and position control cycle. TGRB_0 is used for input capture, with TGRB_0 and TGRD_0 operating in buffer mode. The channel 1 counter input clock is designated as the TGRB_0 input capture source, and the pulse width of 2-phase encoder 4-multiplication pulses is detected. TGRA_1 and TGRB_1 for channel 1 are designated for input capture, channel 0 TGRA_0 and TGRC_0 compare matches are selected as the input capture source, and the up/down-counter values for the control cycles are stored. This procedure enables accurate position/speed detection to be achieved.
Channel 1 TCLKA TCLKB Edge detection circuit TCNT_1
TGRA_1 (speed cycle capture) TGRB_1 (position cycle capture)
TCNT_0 + + -
TGRA_0 (speed control cycle) TGRC_0 (position control cycle)
TGRB_0 (pulse width capture)
TGRD_0 (buffer operation) Channel 0
Figure 9.29 Phase Counting Mode Application Example
Rev.2.00 Jun. 28, 2007 Page 369 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.5
Interrupt Sources
There are three kinds of TPU interrupt sources: TGR input capture/compare match, TCNT overflow, and TCNT underflow. Each interrupt source has its own status flag and enable/disable bit, allowing generation of interrupt request signals to be enabled or disabled individually. When an interrupt request is generated, the corresponding status flag in TSR is set to 1. If the corresponding enable/disable bit in TIER is set to 1 at this time, an interrupt is requested. The interrupt request is cleared by clearing the status flag to 0. Relative channel priority levels can be changed by the interrupt controller, but the priority within a channel is fixed. For details, see section 5, Interrupt Controller. Table 9.37 lists the TPU interrupt sources. Table 9.37 TPU Interrupts
Channel 0 Name TGI0A TGI0B TGI0C TGI0D TCI0V 1 TGI1A TGI1B TCI1V TCI1U Interrupt Source TGRA_0 input capture/compare match TGRB_0 input capture/compare match TGRC_0 input capture/compare match TGRD_0 input capture/compare match TCNT_0 overflow TGRA_1 input capture/compare match TGRB_1 input capture/compare match TCNT_1 overflow TCNT_1 underflow Interrupt Flag TGFA_0 TGFB_0 TGFC_0 TGFD_0 TCFV_0 TGFA_1 TGFB_1 TCFV_1 TCFU_1 DTC Activation Possible Possible Possible Possible Not possible Possible Possible Not possible Not possible
Rev.2.00 Jun. 28, 2007 Page 370 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
Channel 2
Name TGI2A TGI2B TCI2V TCI2U
Interrupt Source TGRA_2 input capture/compare match TGRB_2 input capture/compare match TCNT_2 overflow TCNT_2 underflow TGRA_3 input capture/compare match TGRB_3 input capture/compare match TGRC_3 input capture/compare match TGRD_3 input capture/compare match TCNT_3 overflow TGRA_4 input capture/compare match TGRB_4 input capture/compare match TCNT_4 overflow TCNT_4 underflow TGRA_5 input capture/compare match TGRB_5 input capture/compare match TCNT_5 overflow TCNT_5 underflow
Interrupt Flag TGFA_2 TGFB_2 TCFV_2 TCFU_2 TGFA_3 TGFB_3 TGFC_3 TGFD_3 TCFV_3 TGFA_4 TGFB_4 TCFV_4 TCFU_4 TGFA_5 TGFB_5 TCFV_5 TCFU_5
DTC Activation Possible Possible Not possible Not possible Possible Possible Possible Possible Not possible Possible Possible Not possible Not possible Possible Possible Not possible Not possible
3
TGI3A TGI3B TGI3C TGI3D TCI3V
4
TGI4A TGI4B TCI4V TCI4U
5
TGI5A TGI5B TCI5V TCI5U
Note: This table shows the initial state immediately after a reset. The relative channel priority levels can be changed by the interrupt controller.
Rev.2.00 Jun. 28, 2007 Page 371 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(1)
Input Capture/Compare Match Interrupt
An interrupt is requested if the TGIE bit in TIER is set to 1 when the TGF flag in TSR is set to 1 by the occurrence of a TGR input capture/compare match on a channel. The interrupt request is cleared by clearing the TGF flag to 0. The TPU has 16 input capture/compare match interrupts, four each for channels 0 and 3, and two each for channels 1, 2, 4, and 5. (2) Overflow Interrupt
An interrupt is requested if the TCIEV bit in TIER is set to 1 when the TCFV flag in TSR is set to 1 by the occurrence of a TCNT overflow on a channel. The interrupt request is cleared by clearing the TCFV flag to 0. The TPU has six overflow interrupts, one for each channel. (3) Underflow Interrupt
An interrupt is requested if the TCIEU bit in TIER is set to 1 when the TCFU flag in TSR is set to 1 by the occurrence of a TCNT underflow on a channel. The interrupt request is cleared by clearing the TCFU flag to 0. The TPU has four underflow interrupts, one each for channels 1, 2, 4, and 5.
9.6
DTC Activation
The DTC can be activated by the TGR input capture/compare match interrupt for a channel. For details, see section 7, Data Transfer Controller (DTC). A total of 16 TPU input capture/compare match interrupts can be used as DTC activation sources, four each for channels 0 and 3, and two each for channels 1, 2, 4, and 5.
9.7
A/D Converter Activation
The TGRA input capture/compare match for each channel can activate the A/D converter. If the TTGE bit in TIER is set to 1 when the TGFA flag in TSR is set to 1 by the occurrence of a TGRA input capture/compare match on a particular channel, a request to start A/D conversion is sent to the A/D converter. If the TPU conversion start trigger has been selected on the A/D converter side at this time, A/D conversion is started. In the TPU, a total of six TGRA input capture/compare match interrupts can be used as A/D converter conversion start sources, one for each channel.
Rev.2.00 Jun. 28, 2007 Page 372 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.8
9.8.1 (1)
Operation Timing
Input/Output Timing TCNT Count Timing
Figure 9.30 shows TCNT count timing in internal clock operation, and figure 9.31 shows TCNT count timing in external clock operation.
P
Internal clock
Falling edge
Rising edge
Falling edge
TCNT input clock
TCNT
N-1
N
N+1
N+2
Figure 9.30 Count Timing in Internal Clock Operation
P External clock TCNT input clock TCNT N-1 N+1 N+2 Falling edge Rising edge Falling edge
N
Figure 9.31 Count Timing in External Clock Operation
Rev.2.00 Jun. 28, 2007 Page 373 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(2)
Output Compare Output Timing
A compare match signal is generated in the final state in which TCNT and TGR match (the point at which the count value matched by TCNT is updated). When a compare match signal is generated, the output value set in TIOR is output at the output compare output pin (TIOC pin). After a match between TCNT and TGR, the compare match signal is not generated until the TCNT input clock is generated. Figure 9.32 shows output compare output timing.
P TCNT input clock TCNT TGR Compare match signal TIOC pin N N N+1
Figure 9.32 Output Compare Output Timing (3) Input Capture Signal Timing
Figure 9.33 shows input capture signal timing.
P Input capture input Input capture signal TCNT TGR N N+1 N N+2 N+2
Figure 9.33 Input Capture Input Signal Timing
Rev.2.00 Jun. 28, 2007 Page 374 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(4)
Timing for Counter Clearing by Compare Match/Input Capture
Figure 9.34 shows the timing when counter clearing by compare match occurrence is specified, and figure 9.35 shows the timing when counter clearing by input capture occurrence is specified.
P Compare match signal Counter clear signal TCNT TGR N N H'0000
Figure 9.34 Counter Clear Timing (Compare Match)
P Input capture signal Counter clear signal TCNT N H'0000
TGR
N
Figure 9.35 Counter Clear Timing (Input Capture)
Rev.2.00 Jun. 28, 2007 Page 375 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(5)
Buffer Operation Timing
Figures 9.36 and 9.37 show the timings in buffer operation.
P TCNT Compare match signal TGRA, TGRB TGRC, TGRD n N n+1
n
N
Figure 9.36 Buffer Operation Timing (Compare Match)
P Input capture signal TCNT TGRA, TGRB TGRC, TGRD N N+1 N N+1
n
n
N
Figure 9.37 Buffer Operation Timing (Input Capture)
Rev.2.00 Jun. 28, 2007 Page 376 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.8.2 (1)
Interrupt Signal Timing TGF Flag Setting Timing in Case of Compare Match
Figure 9.38 shows the timing for setting of the TGF flag in TSR by compare match occurrence, and the TGI interrupt request signal timing.
P TCNT input clock TCNT TGR Compare match signal TGF flag TGI interrupt N N N+1
Figure 9.38 TGI Interrupt Timing (Compare Match) (2) TGF Flag Setting Timing in Case of Input Capture
Figure 9.39 shows the timing for setting of the TGF flag in TSR by input capture occurrence, and the TGI interrupt request signal timing.
P Input capture signal TCNT N
TGR TGF flag TGI interrupt
N
Figure 9.39 TGI Interrupt Timing (Input Capture)
Rev.2.00 Jun. 28, 2007 Page 377 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(3)
TCFV Flag/TCFU Flag Setting Timing
Figure 9.40 shows the timing for setting of the TCFV flag in TSR by overflow occurrence, and the TCIV interrupt request signal timing. Figure 9.41 shows the timing for setting of the TCFU flag in TSR by underflow occurrence, and the TCIU interrupt request signal timing.
P TCNT input clock TCNT (overflow) Overflow signal TCFV flag TCIV interrupt H'FFFF H'0000
Figure 9.40 TCIV Interrupt Setting Timing
P TCNT input clock TCNT (underflow) Underflow signal TCFU flag H'0000 H'FFFF
TCIU interrupt
Figure 9.41 TCIU Interrupt Setting Timing
Rev.2.00 Jun. 28, 2007 Page 378 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
(4)
Status Flag Clearing Timing
After a status flag is read as 1 by the CPU, it is cleared by writing 0 to it. When the DTC is activated, the flag is cleared automatically. Figure 9.42 shows the timing for status flag clearing by the CPU, and figures 9.43 and 9.44 show the timing for status flag clearing by the DTC.
TSR write cycle T2 T1 P TSR address
Address Write Status flag Interrupt request signal
Figure 9.42 Timing for Status Flag Clearing by CPU The status flag and interrupt request signal are cleared in synchronization with P after the DTC transfer has started, as shown in figure 9.43. If conflict occurs for clearing the status flag and interrupt request signal due to activation of multiple DTC transfers, it will take up to five clock cycles (P) for clearing them, as shown in figure 9.44. The next transfer request is masked for a longer period of either a period until the current transfer ends or a period for five clock cycles (P) from the beginning of the transfer. Note that in the DTC transfer, the status flag may be cleared during outputting the destination address.
Rev.2.00 Jun. 28, 2007 Page 379 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
DTC read cycle T2 T1 P Address Status flag Source address
DTC write cycle T1 T2
Destination address
Period in which the next transfer request is masked Interrupt request signal
Figure 9.43 Timing for Status Flag Clearing by DTC Activation (1)
DTC read cycle P Address Source address Period in which the next transfer request is masked Status flag Interrupt request signal Period of flag clearing
Period of interrupt request signal clearing
DTC write cycle
Destination address
Figure 9.44 Timing for Status Flag Clearing by DTC Activation (2)
Rev.2.00 Jun. 28, 2007 Page 380 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.9
9.9.1
Usage Notes
Module Stop State Setting
Operation of the TPU can be disabled or enabled using the module stop control register. The initial setting is for operation of the TPU to be halted. Register access is enabled by clearing module stop state. For details, see section 18, Power-Down States. 9.9.2 Input Clock Restrictions
The input clock pulse width must be at least 1.5 states in the case of single-edge detection, and at least 2.5 states in the case of both-edge detection. The TPU will not operate properly with a narrower pulse width. In phase counting mode, the phase difference and overlap between the two input clocks must be at least 1.5 states, and the pulse width must be at least 2.5 states. Figure 9.45 shows the input clock conditions in phase counting mode.
Phase Phase difference difference Overlap Overlap TCLKA (TCLKC) TCLKB (TCLKD) Pulse width Pulse width
Pulse width
Pulse width
Note: Phase difference, Overlap 1.5 states Pulse width 2.5 states
Figure 9.45 Phase Difference, Overlap, and Pulse Width in Phase Counting Mode
Rev.2.00 Jun. 28, 2007 Page 381 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.9.3
Caution on Cycle Setting
When counter clearing by compare match is set, TCNT is cleared in the final state in which it matches the TGR value (the point at which the count value matched by TCNT is updated). Consequently, the actual counter frequency is given by the following formula:
f= f: P (N + 1) Counter frequency
P: Operating frequency N: TGR set value
9.9.4
Conflict between TCNT Write and Clear Operations
If the counter clearing signal is generated in the T2 state of a TCNT write cycle, TCNT clearing takes precedence and the TCNT write is not performed. Figure 9.46 shows the timing in this case.
TCNT write cycle T1 T2 P Address Write Counter clear signal TCNT N H'0000 TCNT address
Figure 9.46 Conflict between TCNT Write and Clear Operations
Rev.2.00 Jun. 28, 2007 Page 382 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.9.5
Conflict between TCNT Write and Increment Operations
If incrementing occurs in the T2 state of a TCNT write cycle, the TCNT write takes precedence and TCNT is not incremented. Figure 9.47 shows the timing in this case.
TCNT write cycle T1 T2 P Address Write TCNT input clock TCNT N TCNT write data M TCNT address
Figure 9.47 Conflict between TCNT Write and Increment Operations 9.9.6 Conflict between TGR Write and Compare Match
If a compare match occurs in the T2 state of a TGR write cycle, the TGR write takes precedence and the compare match signal is disabled. A compare match also does not occur when the same value as before is written. Figure 9.48 shows the timing in this case.
TGR write cycle T1 T2 P Address Write Compare match signal TCNT TGR N N TGR write data N+1 M Disabled TGR address
Figure 9.48 Conflict between TGR Write and Compare Match
Rev.2.00 Jun. 28, 2007 Page 383 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.9.7
Conflict between Buffer Register Write and Compare Match
If a compare match occurs in the T2 state of a TGR write cycle, the data transferred to TGR by the buffer operation will be the write data. Figure 9.49 shows the timing in this case.
TGR write cycle T2 T1 P Address Write Compare match signal Buffer register N Data written to buffer register Buffer register address
M
TGR
M
Figure 9.49 Conflict between Buffer Register Write and Compare Match 9.9.8 Conflict between TGR Read and Input Capture
If the input capture signal is generated in the T1 state of a TGR read cycle, the data that is read will be the data after input capture transfer. Figure 9.50 shows the timing in this case.
Rev.2.00 Jun. 28, 2007 Page 384 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
TGR read cycle T1 T2 P Address Read TGR address
Input capture signal TGR Internal data bus X M M
Figure 9.50 Conflict between TGR Read and Input Capture 9.9.9 Conflict between TGR Write and Input Capture
If the input capture signal is generated in the T2 state of a TGR write cycle, the input capture operation takes precedence and the write to TGR is not performed. Figure 9.51 shows the timing in this case.
TGR write cycle T2 T1 P Address Write Input capture signal TCNT M TGR address
TGR
M
Figure 9.51 Conflict between TGR Write and Input Capture
Rev.2.00 Jun. 28, 2007 Page 385 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.9.10
Conflict between Buffer Register Write and Input Capture
If the input capture signal is generated in the T2 state of a buffer register write cycle, the buffer operation takes precedence and the write to the buffer register is not performed. Figure 9.52 shows the timing in this case.
Buffer register write cycle T1 T2 P Address Write Input capture signal Buffer register address
TCNT TGR Buffer register
N
M
N M
Figure 9.52 Conflict between Buffer Register Write and Input Capture
Rev.2.00 Jun. 28, 2007 Page 386 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.9.11
Conflict between Overflow/Underflow and Counter Clearing
If overflow/underflow and counter clearing occur simultaneously, the TCFV/TCFU flag in TSR is not set and TCNT clearing takes precedence. Figure 9.53 shows the operation timing when a TGR compare match is specified as the clearing source, and H'FFFF is set in TGR.
P TCNT input clock TCNT Counter clear signal H'FFFF H'0000
TGF flag TCFV flag Disabled
Figure 9.53 Conflict between Overflow and Counter Clearing 9.9.12 Conflict between TCNT Write and Overflow/Underflow
If an overflow/underflow occurs due to increment/decrement in the T2 state of a TCNT write cycle, the TCNT write takes precedence and the TCFV/TCFU flag in TSR is not set. Figure 9.54 shows the operation timing when there is conflict between TCNT write and overflow.
TGR write cycle T1 T2 P Address Write TCNT write data TCNT TCFV flag H'FFFF M TCNT address
Figure 9.54 Conflict between TCNT Write and Overflow
Rev.2.00 Jun. 28, 2007 Page 387 of 666 REJ09B0311-0200
Section 9 16-Bit Timer Pulse Unit (TPU)
9.9.13
Multiplexing of I/O Pins
In this LSI, the TCLKA input pin is multiplexed with the TIOCC0 I/O pin, the TCLKB input pin with the TIOCD0 I/O pin, the TCLKC input pin with the TIOCB1 I/O pin, and the TCLKD input pin with the TIOCB2 I/O pin. When an external clock is input, compare match output should not be performed from a multiplexed pin. 9.9.14 Interrupts and Module Stop State
If the module stop state is entered when an interrupt has been requested, it will not be possible to clear the CPU interrupt source or the DTC activation source. Interrupts should therefore be disabled before entering the module stop state.
Rev.2.00 Jun. 28, 2007 Page 388 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
Section 10 Programmable Pulse Generator (PPG)
The programmable pulse generator (PPG) provides pulse outputs by using the 16-bit timer pulse unit (TPU) as a time base. The PPG pulse outputs are divided into 4-bit groups (groups 3 to 0) that can operate both simultaneously and independently. Figure 10.1 shows a block diagram of the PPG.
10.1
* * * * * * *
Features
16-bit output data Four output groups Selectable output trigger signals Non-overlapping mode Can operate together with the data transfer controller (DTC) Inverted output can be set Module stop state specifiable
Rev.2.00 Jun. 28, 2007 Page 389 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
Compare match signals
NDERH Control logic PMR
NDERL PCR
PO15 PO14 PO13 PO12 PO11 PO10 PO9 PO8 PO7 PO6 PO5 PO4 PO3 PO2 PO1 PO0 [Legend] PMR: PCR: NDERH: NDERL: NDRH: NDRL: PODRH: PODRL:
Pulse output pins, group 3 PODRH Pulse output pins, group 2 Pulse output pins, group 1 PODRL Pulse output pins, group 0 NDRL NDRH
Internal data bus
PPG output mode register PPG output control register Next data enable register H Next data enable register L Next data register H Next data register L Output data register H Output data register L
Figure 10.1 Block Diagram of PPG
Rev.2.00 Jun. 28, 2007 Page 390 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
10.2
Input/Output Pins
Table 10.1 shows the PPG pin configuration. Table 10.1 Pin Configuration
Pin Name PO15 PO14 PO13 PO12 PO11 PO10 PO9 PO8 PO7 PO6 PO5 PO4 PO3 PO2 PO1 PO0 I/O Output Output Output Output Output Output Output Output Output Output Output Output Output Output Output Output Group 0 pulse output Group 1 pulse output Group 2 pulse output Function Group 3 pulse output
Rev.2.00 Jun. 28, 2007 Page 391 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
10.3
Register Descriptions
The PPG has the following registers. * * * * * * * * Next data enable register H (NDERH) Next data enable register L (NDERL) Output data register H (PODRH) Output data register L (PODRL) Next data register H (NDRH) Next data register L (NDRL) PPG output control register (PCR) PPG output mode register (PMR) Next Data Enable Registers H, L (NDERH, NDERL)
10.3.1
NDERH and NDERL enable/disable pulse output on a bit-by-bit basis. * NDERH
Bit Bit Name Initial Value R/W 7 NDER15 0 R/W 6 NDER14 0 R/W 5 NDER13 0 R/W 4 NDER12 0 R/W 3 NDER11 0 R/W 2 NDER10 0 R/W 1 NDER9 0 R/W 0 NDER8 0 R/W
* NDERL
Bit Bit Name Initial Value R/W 7 NDER7 0 R/W 6 NDER6 0 R/W 5 NDER5 0 R/W 4 NDER4 0 R/W 3 NDER3 0 R/W 2 NDER2 0 R/W 1 NDER1 0 R/W 0 NDER0 0 R/W
Rev.2.00 Jun. 28, 2007 Page 392 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
* NDERH
Bit 7 6 5 4 3 2 1 0 Bit Name NDER15 NDER14 NDER13 NDER12 NDER11 NDER10 NDER9 NDER8 Initial Value 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W R/W Description Next Data Enable 15 to 8 When a bit is set to 1, the value in the corresponding NDRH bit is transferred to the PODRH bit by the selected output trigger. Values are not transferred from NDRH to PODRH for cleared bits.
* NDERL
Bit 7 6 5 4 3 2 1 0 Bit Name NDER7 NDER6 NDER5 NDER4 NDER3 NDER2 NDER1 NDER0 Initial Value 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W R/W Description Next Data Enable 7 to 0 When a bit is set to 1, the value in the corresponding NDRL bit is transferred to the PODRL bit by the selected output trigger. Values are not transferred from NDRL to PODRL for cleared bits.
Rev.2.00 Jun. 28, 2007 Page 393 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
10.3.2
Output Data Registers H, L (PODRH, PODRL)
PODRH and PODRL store output data for use in pulse output. A bit that has been set for pulse output by NDER is read-only and cannot be modified. * PODRH
Bit Bit Name Initial Value R/W 7 POD15 0 R/W 6 POD14 0 R/W 5 POD13 0 R/W 4 POD12 0 R/W 3 POD11 0 R/W 2 POD10 0 R/W 1 POD9 0 R/W 0 POD8 0 R/W
* PODRL
Bit Bit Name Initial Value R/W 7 POD7 0 R/W 6 POD6 0 R/W 5 POD5 0 R/W 4 POD4 0 R/W 3 POD3 0 R/W 2 POD2 0 R/W 1 POD2 0 R/W 0 POD0 0 R/W
* PODRH
Bit 7 6 5 4 3 2 1 0 Bit Name POD15 POD14 POD13 POD12 POD11 POD10 POD9 POD8 Initial Value 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W R/W Description Output Data Register 15 to 8 For bits which have been set to pulse output by NDERH, the output trigger transfers NDRH values to this register during PPG operation. While NDERH is set to 1, the CPU cannot write to this register. While NDERH is cleared, the initial output value of the pulse can be set.
Rev.2.00 Jun. 28, 2007 Page 394 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
* PODRL
Bit 7 6 5 4 3 2 1 0 Bit Name POD7 POD6 POD5 POD4 POD3 POD2 POD1 POD0 Initial Value 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W R/W Description Output Data Register 7 to 0 For bits which have been set to pulse output by NDERL, the output trigger transfers NDRL values to this register during PPG operation. While NDERL is set to 1, the CPU cannot write to this register. While NDERL is cleared, the initial output value of the pulse can be set.
10.3.3
Next Data Registers H, L (NDRH, NDRL)
NDRH and NDRL store the next data for pulse output. The NDR addresses differ depending on whether pulse output groups have the same output trigger or different output triggers. * NDRH
Bit Bit Name Initial Value R/W 7 NDR15 0 R/W 6 NDR14 0 R/W 5 NDR13 0 R/W 4 NDR12 0 R/W 3 NDR11 0 R/W 2 NDR10 0 R/W 1 NDR9 0 R/W 0 NDR8 0 R/W
* NDRL
Bit Bit Name Initial Value R/W 7 NDR7 0 R/W 6 NDR6 0 R/W 5 NDR5 0 R/W 4 NDR4 0 R/W 3 NDR3 0 R/W 2 NDR2 0 R/W 1 NDR1 0 R/W 0 NDR0 0 R/W
Rev.2.00 Jun. 28, 2007 Page 395 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
* NDRH If pulse output groups 2 and 3 have the same output trigger, all eight bits are mapped to the same address and can be accessed at one time, as shown below.
Bit 7 6 5 4 3 2 1 0 Bit Name NDR15 NDR14 NDR13 NDR12 NDR11 NDR10 NDR9 NDR8 Initial Value 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W R/W Description Next Data Register 15 to 8 The register contents are transferred to the corresponding PODRH bits by the output trigger specified with PCR.
If pulse output groups 2 and 3 have different output triggers, the upper four bits and lower four bits are mapped to different addresses as shown below.
Bit 7 6 5 4 3 to 0 Bit Name NDR15 NDR14 NDR13 NDR12 Initial Value 0 0 0 0 All 1 R/W R/W R/W R/W R/W Description Next Data Register 15 to 12 The register contents are transferred to the corresponding PODRH bits by the output trigger specified with PCR. Reserved These bits are always read as 1 and cannot be modified.
Bit 7 to 4 3 2 1 0
Bit Name NDR11 NDR10 NDR9 NDR8
Initial Value All 1 0 0 0 0
R/W R/W R/W R/W R/W
Description Reserved These bits are always read as 1 and cannot be modified. Next Data Register 11 to 8 The register contents are transferred to the corresponding PODRH bits by the output trigger specified with PCR.
Rev.2.00 Jun. 28, 2007 Page 396 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
* NDRL If pulse output groups 0 and 1 have the same output trigger, all eight bits are mapped to the same address and can be accessed at one time, as shown below.
Bit 7 6 5 4 3 2 1 0 Bit Name NDR7 NDR6 NDR5 NDR4 NDR3 NDR2 NDR1 NDR0 Initial Value 0 0 0 0 0 0 0 0 R/W R/W R/W R/W R/W R/W R/W R/W R/W Description Next Data Register 7 to 0 The register contents are transferred to the corresponding PODRL bits by the output trigger specified with PCR.
If pulse output groups 0 and 1 have different output triggers, the upper four bits and lower four bits are mapped to different addresses as shown below.
Bit 7 6 5 4 3 to 0 Bit Name NDR7 NDR6 NDR5 NDR4 Initial Value 0 0 0 0 All 1 R/W R/W R/W R/W R/W Description Next Data Register 7 to 4 The register contents are transferred to the corresponding PODRL bits by the output trigger specified with PCR. Reserved These bits are always read as 1 and cannot be modified.
Bit 7 to 4 3 2 1 0
Bit Name NDR3 NDR2 NDR1 NDR0
Initial Value All 1 0 0 0 0
R/W R/W R/W R/W R/W
Description Reserved These bits are always read as 1 and cannot be modified. Next Data Register 3 to 0 The register contents are transferred to the corresponding PODRL bits by the output trigger specified with PCR.
Rev.2.00 Jun. 28, 2007 Page 397 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
10.3.4
PPG Output Control Register (PCR)
PCR selects output trigger signals on a group-by-group basis. For details on output trigger selection, refer to section 10.3.5, PPG Output Mode Register (PMR).
Bit Bit Name Initial Value R/W 7 G3CMS1 1 R/W 6 G3CMS0 1 R/W 5 G2CMS1 1 R/W 4 G2CMS0 1 R/W 3 G1CMS1 1 R/W 2 G1CMS0 1 R/W 1 G0CMS1 1 R/W 0 G0CMS0 1 R/W
Bit 7 6
Bit Name G3CMS1 G3CMS0
Initial Value 1 1
R/W R/W R/W
Description Group 3 Compare Match Select 1 and 0 These bits select output trigger of pulse output group 3. 00: Compare match in TPU channel 0 01: Compare match in TPU channel 1 10: Compare match in TPU channel 2 11: Compare match in TPU channel 3
5 4
G2CMS1 G2CMS0
1 1
R/W R/W
Group 2 Compare Match Select 1 and 0 These bits select output trigger of pulse output group 2. 00: Compare match in TPU channel 0 01: Compare match in TPU channel 1 10: Compare match in TPU channel 2 11: Compare match in TPU channel 3
3 2
G1CMS1 G1CMS0
1 1
R/W R/W
Group 1 Compare Match Select 1 and 0 These bits select output trigger of pulse output group 1. 00: Compare match in TPU channel 0 01: Compare match in TPU channel 1 10: Compare match in TPU channel 2 11: Compare match in TPU channel 3
1 0
G0CMS1 G0CMS0
1 1
R/W R/W
Group 0 Compare Match Select 1 and 0 These bits select output trigger of pulse output group 0. 00: Compare match in TPU channel 0 01: Compare match in TPU channel 1 10: Compare match in TPU channel 2 11: Compare match in TPU channel 3
Rev.2.00 Jun. 28, 2007 Page 398 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
10.3.5
PPG Output Mode Register (PMR)
PMR selects the pulse output mode of the PPG for each group. If inverted output is selected, a low-level pulse is output when PODRH is 1 and a high-level pulse is output when PODRH is 0. If non-overlapping operation is selected, PPG updates its output values at compare match A or B of the TPU that becomes the output trigger. For details, refer to section 10.4.4, Non-Overlapping Pulse Output.
Bit Bit Name Initial Value R/W 7 G3INV 1 R/W 6 G2INV 1 R/W 5 G1INV 1 R/W 4 G0INV 1 R/W 3 G3NOV 0 R/W 2 G2NOV 0 R/W 1 G1NOV 0 R/W 0 G0NOV 0 R/W
Bit 7
Bit Name G3INV
Initial Value 1
R/W R/W
Description Group 3 Inversion Selects direct output or inverted output for pulse output group 3. 0: Inverted output 1: Direct output
6
G2INV
1
R/W
Group 2 Inversion Selects direct output or inverted output for pulse output group 2. 0: Inverted output 1: Direct output
5
G1INV
1
R/W
Group 1 Inversion Selects direct output or inverted output for pulse output group 1. 0: Inverted output 1: Direct output
4
G0INV
1
R/W
Group 0 Inversion Selects direct output or inverted output for pulse output group 0. 0: Inverted output 1: Direct output
Rev.2.00 Jun. 28, 2007 Page 399 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
Bit 3
Bit Name G3NOV
Initial Value 0
R/W R/W
Description Group 3 Non-Overlap Selects normal or non-overlapping operation for pulse output group 3. 0: Normal operation (output values updated at compare match A in the selected TPU channel) 1: Non-overlapping operation (output values updated at compare match A or B in the selected TPU channel)
2
G2NOV
0
R/W
Group 2 Non-Overlap Selects normal or non-overlapping operation for pulse output group 2. 0: Normal operation (output values updated at compare match A in the selected TPU channel) 1: Non-overlapping operation (output values updated at compare match A or B in the selected TPU channel)
1
G1NOV
0
R/W
Group 1 Non-Overlap Selects normal or non-overlapping operation for pulse output group 1. 0: Normal operation (output values updated at compare match A in the selected TPU channel) 1: Non-overlapping operation (output values updated at compare match A or B in the selected TPU channel)
0
G0NOV
0
R/W
Group 0 Non-Overlap Selects normal or non-overlapping operation for pulse output group 0. 0: Normal operation (output values updated at compare match A in the selected TPU channel) 1: Non-overlapping operation (output values updated at compare match A or B in the selected TPU channel)
Rev.2.00 Jun. 28, 2007 Page 400 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
10.4
Operation
Figure 10.2 shows a schematic diagram of the PPG. PPG pulse output is enabled when the corresponding bits in NDER are set to 1. An initial output value is determined by its corresponding PODR initial setting. When the compare match event specified by PCR occurs, the corresponding NDR bit contents are transferred to PODR to update the output values. Sequential output of data of up to 16 bits is possible by writing new output data to NDR before the next compare match.
NDER Q Output trigger signal
C Q PODR D Pulse output pin Normal output/inverted output
Q NDR D
Internal data bus
Figure 10.2 Schematic Diagram of PPG 10.4.1 Output Timing
If pulse output is enabled, the NDR contents are transferred to PODR and output when the specified compare match event occurs. Figure 10.3 shows the timing of these operations for the case of normal output in groups 2 and 3, triggered by compare match A.
P TCNT TGRA Compare match A signal NDRH PODRH PO8 to PO15 m m n n n N N N+1
Figure 10.3 Timing of Transfer and Output of NDR Contents (Example)
Rev.2.00 Jun. 28, 2007 Page 401 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
10.4.2
Sample Setup Procedure for Normal Pulse Output
Figure 10.4 shows a sample procedure for setting up normal pulse output.
[1] [2] [3] Set TGRA value TPU setup Set counting operation Select interrupt request Set initial output data Enable pulse output PPG setup Select output trigger Set next pulse output data TPU setup Start counter Compare match? Yes Set next pulse output data [10] [7] [3] [4] [4] [5] [6] [5] [6] [7] [8] [9] [9] No [2] Set TIOR to make TGRA an output compare register (with output disabled). Set the PPG output trigger cycle. Select the counter clock source with bits TPSC2 to TPSC0 in TCR. Select the counter clear source with bits CCLR1 and CCLR0. Enable the TGIA interrupt in TIER. The DTC can also be set up to transfer data to NDR. Set the initial output values in PODR. Set the bits in NDER for the pins to be used for pulse output to 1. Select the TPU compare match event to be used as the output trigger in PCR. Set the next pulse output values in NDR. Set the CST bit in TSTR to 1 to start the TCNT counter.
Normal PPG output Select TGR functions [1]
[8]
[10] At each TGIA interrupt, set the next output values in NDR.
Figure 10.4 Setup Procedure for Normal Pulse Output (Example)
Rev.2.00 Jun. 28, 2007 Page 402 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
10.4.3
Example of Normal Pulse Output (Example of 5-Phase Pulse Output)
Figure 10.5 shows an example in which pulse output is used for cyclic 5-phase pulse output.
TCNT value TGRA TCNT Compare match
H'0000 NDRH 80 C0 40 60 20 30 10 18 08 88 80 C0 40
Time
PODRH
00
80
C0
40
60
20
30
10
18
08
88
80
C0
PO15
PO14
PO13
PO12
PO11
Figure 10.5 Normal Pulse Output Example (5-Phase Pulse Output)
Rev.2.00 Jun. 28, 2007 Page 403 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
1. Set up TGRA in TPU which is used as the output trigger to be an output compare register. Set a cycle in TGRA so the counter will be cleared by compare match A. Set the TGIEA bit in TIER to 1 to enable the compare match/input capture A (TGIA) interrupt. 2. Write H'F8 to NDERH, and set bits G3CMS1, G3CMS0, G2CMS1, and G2CMS0 in PCR to select compare match in the TPU channel set up in the previous step to be the output trigger. Write output data H'80 in NDRH. 3. The timer counter in the TPU channel starts. When compare match A occurs, the NDRH contents are transferred to PODRH and output. The TGIA interrupt handling routine writes the next output data (H'C0) in NDRH. 4. 5-phase pulse output (one or two phases active at a time) can be obtained subsequently by writing H'40, H'60, H'20, H'30, H'10, H'18, H'08, H'88... at successive TGIA interrupts. If the DTC is set for activation by the TGIA interrupt, pulse output can be obtained without imposing a load on the CPU. 10.4.4 Non-Overlapping Pulse Output
During non-overlapping operation, transfer from NDR to PODR is performed as follows: * At compare match A, the NDR bits are always transferred to PODR. * At compare match B, the NDR bits are transferred only if their value is 0. The NDR bits are not transferred if their value is 1. Figure 10.6 illustrates the non-overlapping pulse output operation.
NDER Q Compare match A Compare match B
Pulse output pin
C Q PODR D
Q NDR D
Internal data bus
Normal output/inverted output
Figure 10.6 Non-Overlapping Pulse Output
Rev.2.00 Jun. 28, 2007 Page 404 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
Therefore, 0 data can be transferred ahead of 1 data by making compare match B occur before compare match A. The NDR contents should not be altered during the interval from compare match B to compare match A (the non-overlapping margin). This can be accomplished by having the TGIA interrupt handling routine write the next data in NDR, or by having the TGIA interrupt activate the DTC. Note, however, that the next data must be written before the next compare match B occurs. Figure 10.7 shows the timing of this operation.
Compare match A
Compare match B Write to NDR NDR Write to NDR
PODR 0 output 0/1 output 0 output 0/1 output Write to NDR here
Write to NDR Do not write here to NDR here
Do not write to NDR here
Figure 10.7 Non-Overlapping Operation and NDR Write Timing
Rev.2.00 Jun. 28, 2007 Page 405 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
10.4.5
Sample Setup Procedure for Non-Overlapping Pulse Output
Figure 10.8 shows a sample procedure for setting up non-overlapping pulse output.
Non-overlapping pulse output Select TGR functions Set TGR values TPU setup Set counting operation Select interrupt request Set initial output data Enable pulse output Select output trigger Set non-overlapping groups Set next pulse output data TPU setup Start counter [3] [4] [4] [5] [6] [7] [8] [7] [5] [6] PPG setup [1] [2] [3] [1] Set TIOR to make TGRA and TGRB output compare registers (with output disabled). Set the pulse output trigger cycle in TGRB and the non-overlapping margin in TGRA. Select the counter clock source with bits TPSC2 to TPSC0 in TCR. Select the counter clear source with bits CCLR1 and CCLR0. Enable the TGIA interrupt in TIER. The DTC can also be set up to transfer data to NDR. Set the initial output values in PODR. Set the bits in NDER for the pins to be used for pulse output to 1. Select the TPU compare match event to be used as the pulse output trigger in PCR. In PMR, select the groups that will operate in non-overlapping mode. Set the next pulse output values in NDR.
[2]
[9]
[8] [9]
[10]
Compare match A? Yes Set next pulse output data
No
[10] Set the CST bit in TSTR to 1 to start the TCNT counter. [11] At each TGIA interrupt, set the next output values in NDR.
[11]
Figure 10.8 Setup Procedure for Non-Overlapping Pulse Output (Example)
Rev.2.00 Jun. 28, 2007 Page 406 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
10.4.6
Example of Non-Overlapping Pulse Output (Example of 4-Phase Complementary Non-Overlapping Pulse Output)
Figure 10.9 shows an example in which pulse output is used for 4-phase complementary nonoverlapping pulse output.
TCNT value TGRB TCNT TGRA H'0000 NDRH 95 65 59 56 95 65 Time
PODRH
00
95
05
65
41
59
50
56
14
95
05
65
Non-overlapping margin PO15
PO14
PO13
PO12
PO11
PO10
PO9
PO8
Figure 10.9 Non-Overlapping Pulse Output Example (4-Phase Complementary)
Rev.2.00 Jun. 28, 2007 Page 407 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
1. Set up the TPU channel to be used as the output trigger channel so that TGRA and TGRB are output compare registers. Set the cycle in TGRB and the non-overlapping margin in TGRA, and set the counter to be cleared by compare match B. Set the TGIEA bit in TIER to 1 to enable the TGIA interrupt. 2. Write H'FF to NDERH, and set bits G3CMS1, G3CMS0, G2CMS1, and G2CMS0 in PCR to select compare match in the TPU channel set up in the previous step to be the output trigger. Set bits G3NOV and G2NOV in PMR to 1 to select non-overlapping pulse output. Write output data H'95 to NDRH. 3. The timer counter in the TPU channel starts. When a compare match with TGRB occurs, outputs change from 1 to 0. When a compare match with TGRA occurs, outputs change from 0 to 1 (the change from 0 to 1 is delayed by the value set in TGRA). The TGIA interrupt handling routine writes the next output data (H'65) to NDRH. 4. 4-phase complementary non-overlapping pulse output can be obtained subsequently by writing H'59, H'56, H'95... at successive TGIA interrupts. If the DTC is set for activation by a TGIA interrupt, pulse can be output without imposing a load on the CPU.
Rev.2.00 Jun. 28, 2007 Page 408 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
10.4.7
Inverted Pulse Output
If the G3INV, G2INV, G1INV, and G0INV bits in PMR are cleared to 0, values that are the inverse of the PODR contents can be output. Figure 10.10 shows the outputs when the G3INV and G2INV bits are cleared to 0, in addition to the settings of figure 10.9.
TCNT value TGRB TCNT TGRA H'0000 NDRH 95 65 59 56 95 65 Time
PODRL
00
95
05
65
41
59
50
56
14
95
05
65
PO15
PO14
PO13
PO12
PO11
PO10
PO9
PO8
Figure 10.10 Inverted Pulse Output (Example)
Rev.2.00 Jun. 28, 2007 Page 409 of 666 REJ09B0311-0200
Section 10 Programmable Pulse Generator (PPG)
10.4.8
Pulse Output Triggered by Input Capture
Pulse output can be triggered by TPU input capture as well as by compare match. If TGRA functions as an input capture register in the TPU channel selected by PCR, pulse output will be triggered by the input capture signal. Figure 10.11 shows the timing of this output.
P TIOC pin Input capture signal NDR PODR PO M M N N N
Figure 10.11 Pulse Output Triggered by Input Capture (Example)
10.5
10.5.1
Usage Notes
Module Stop State Setting
PPG operation can be disabled or enabled using the module stop control register. The initial value is for PPG operation to be halted. Register access is enabled by clearing module stop state. For details, refer to section 18, Power-Down States. 10.5.2 Operation of Pulse Output Pins
Pins PO0 to PO15 are also used for other peripheral functions such as the TPU. When output by another peripheral function is enabled, the corresponding pins cannot be used for pulse output. Note, however, that data transfer from NDR bits to PODR bits takes place, regardless of the usage of the pins. Pin functions should be changed only under conditions in which the output trigger event will not occur.
Rev.2.00 Jun. 28, 2007 Page 410 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
Section 11 8-Bit Timers (TMR)
This LSI has two units (unit 0 and unit 1) of an on-chip 8-bit timer module that comprise two 8-bit counter channels, totaling four channels. The 8-bit timer module can be used to count external events and also be used as a multifunction timer in a variety of applications, such as generation of counter reset, interrupt requests, and pulse output with a desired duty cycle using a compare-match signal with two registers. Figures 11.1 and 11.2 show block diagrams of the 8-bit timer module (unit 0 and unit 1). This section describes unit 0 (channels 0 and 1), which has the same functions as the other unit.
11.1
Features
* Selection of seven clock sources The counters can be driven by one of six internal clock signals (P/2, P/18, P/32, P/164, P/1024, or P/8192) or an external clock input. * Selection of three ways to clear the counters The counters can be cleared on compare match A or B, or by an external reset signal. * Timer output control by a combination of two compare match signals The timer output signal in each channel is controlled by a combination of two independent compare match signals, enabling the timer to output pulses with a desired duty cycle or PWM output. * Cascading of two channels (TMR_0 and TMR_1) Operation as a 16-bit timer is possible, using TMR_0 for the upper 8 bits and TMR_1 for the lower 8 bits (16-bit count mode). TMR_1 can be used to count TMR_0 compare matches (compare match count mode). * Three interrupt sources Compare match A, compare match B, and overflow interrupts can be requested independently. * Generation of trigger to start A/D converter conversion * Module stop state specifiable
Rev.2.00 Jun. 28, 2007 Page 411 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
Internal clocks P/2 P/8 P/32 P/64 P/1024 P/8192 External clocks TMCI0 TMCI1 Clock select TCORA_0 Compare match A1 Compare match A0 Comparator A_0 Overflow 1 Overflow 0 Counter clear 0 Counter clear 1 Compare match B1 Compare match B0 Control logic TCORB_0 A/D conversion start request signal TCSR_0 TCR_0 TCCR_0 CMIA0 CMIA1 CMIB0 CMIB1 OVI0 OVI1 Interrupt signals [Legend] TCORA_0: TCNT_0: TCORB_0: TCSR_0: TCR_0: TCCR_0: Time constant register A_0 Timer counter_0 Time constant register B_0 Timer control/status register_0 Timer control register_0 Timer counter control register_0 TCORA_1: TCNT_1: TCORB_1: TCSR_1: TCR_1: TCCR_1: Time constant register A_1 Timer counter_1 Time constant register B_1 Timer control/status register_1 Timer control register_1 Timer counter control register_1 TCORB_1 TCSR_1 TCR_1 TCCR_1 TCORA_1 Counter clock 1 Counter clock 0
Comparator A_1
TMO0 TMO1
TCNT_0
TCNT_1
Internal bus
Comparator B_0
Comparator B_1
TMRI0 TMRI1
Figure 11.1 Block Diagram of 8-Bit Timer Module (Unit 0)
Rev.2.00 Jun. 28, 2007 Page 412 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
Internal clocks P/2 P/8 P/32 P/64 P/1024 P/8192 External clocks TMCI2 TMCI3 Counter clock 3 Counter clock 2 Clock select TCORA_2 Compare match A3 Compare match A2 Comparator A_3 Overflow 3 Overflow 2 Counter clear 2 Counter clear 3 Compare match B3 Compare match B2 Control logic TCORB_2 A/D conversion start request signal TCORB_3 TCORA_3
Comparator A_3
TMO2 TMO3
TCNT_2
TCNT_3
Internal bus
Comparator B_2
Comparator B_3
TMRI2 TMRI3
TCSR_2 TCR_2 TCCR_2 CMIA2 CMIA3 CMIB2 CMIB3 OVI2 OVI3 Interrupt signals Time constant register A_2 Timer counter_2 Time constant register B_2 Timer control/status register_2 Timer control register_2 Timer counter control register_2 TCORA_3: TCNT_3: TCORB_3: TCSR_3: TCR_3: TCCR_3:
TCSR_3 TCR_3 TCCR_3
[Legend] TCORA_2: TCNT_2: TCORB_2: TCSR_2: TCR_2: TCCR_2:
Time constant register A_3 Timer counter_3 Time constant register B_3 Timer control/status register_3 Timer control register_3 Timer counter control register_3
Figure 11.2 Block Diagram of 8-Bit Timer Module (Unit 1)
Rev.2.00 Jun. 28, 2007 Page 413 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
11.2
Input/Output Pins
Table 11.1 shows the pin configuration of the TMR. Table 11.1 Pin Configuration
Unit 0 Channel Name 0 Timer output pin Timer clock input pin Timer reset input pin 1 Timer output pin Timer clock input pin Timer reset input pin 1 2 Timer output pin Timer clock input pin Timer reset input pin 3 Timer output pin Timer clock input pin Timer reset input pin Symbol TMO0 TMCI0 TMRI0 TMO1 TMCI1 TMRI1 TMO2 TMCI2 TMRI2 TMO3 TMCI3 TMRI3 I/O Function
Output Outputs compare match Input Input Inputs external clock for counter Inputs external reset to counter
Output Outputs compare match Input Input Inputs external clock for counter Inputs external reset to counter
Output Outputs compare match Input Input Inputs external clock for counter Inputs external reset to counter
Output Outputs compare match Input Input Inputs external clock for counter Inputs external reset to counter
Rev.2.00 Jun. 28, 2007 Page 414 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
11.3
Register Descriptions
The TMR has the following registers. Unit 0: * Channel 0 Timer counter_0 (TCNT_0) Time constant register A_0 (TCORA_0) Time constant register B_0 (TCORB_0) Timer control register_0 (TCR_0) Timer counter control register_0 (TCCR_0) Timer control/status register_0 (TCSR_0) * Channel 1 Timer counter_1 (TCNT_1) Time constant register A_1 (TCORA_1) Time constant register B_1 (TCORB_1) Timer control register_1 (TCR_1) Timer counter control register_1 (TCCR_1) Timer control/status register_1 (TCSR_1) Unit 1: * Channel 2 Timer counter_2 (TCNT_2) Time constant register A_2 (TCORA_2) Time constant register B_2 (TCORB_2) Timer control register_2 (TCR_2) Timer counter control register_2 (TCCR_2) Timer control/status register_2 (TCSR_2) * Channel 3 Timer counter_3 (TCNT_3) Time constant register A_3 (TCORA_3) Time constant register B_3 (TCORB_3) Timer control register_3 (TCR_3) Timer counter control register_3 (TCCR_3) Timer control/status register_3 (TCSR_3)
Rev.2.00 Jun. 28, 2007 Page 415 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
11.3.1
Timer Counter (TCNT)
TCNT is an 8-bit readable/writable up-counter. TCNT_0 and TCNT_1 comprise a single 16-bit register so they can be accessed together by a word transfer instruction. Bits CKS2 to CKS0 in TCR and bits ICKS1 and ICKS0 in TCCR are used to select a clock. TCNT can be cleared by an external reset input signal, compare match A signal, or compare match B signal. Which signal is to be used for clearing is selected by bits CCLR1 and CCLR0 in TCR. When TCNT overflows from H'FF to H'00, bit OVF in TCSR is set to 1. TCNT is initialized to H'00.
TCNT_0 4 3 TCNT_1 4 3
Bit Bit Name Initial Value R/W
7
6
5
2
1
0
7
6
5
2
1
0
0 R/W
0 R/W
0 R/W
0 R/W
0 R/W
0 R/W
0 R/W
0 R/W
0 R/W
0 R/W
0 R/W
0 R/W
0 R/W
0 R/W
0 R/W
0 R/W
11.3.2
Time Constant Register A (TCORA)
TCORA is an 8-bit readable/writable register. TCORA_0 and TCORA_1 comprise a single 16-bit register so they can be accessed together by a word transfer instruction. The value in TCORA is continually compared with the value in TCNT. When a match is detected, the corresponding CMFA flag in TCSR is set to 1. Note however that comparison is disabled during the T2 state of a TCORA write cycle. The timer output from the TMO pin can be freely controlled by this compare match signal (compare match A) and the settings of bits OS1 and OS0 in TCSR. TCORA is initialized to H'FF.
TCORA_0 4 3 TCORA_1 4 3
Bit Bit Name Initial Value R/W
7
6
5
2
1
0
7
6
5
2
1
0
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
Rev.2.00 Jun. 28, 2007 Page 416 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
11.3.3
Time Constant Register B (TCORB)
TCORB is an 8-bit readable/writable register. TCORB_0 and TCORB_1 comprise a single 16-bit register so they can be accessed together by a word transfer instruction. TCORB is continually compared with the value in TCNT. When a match is detected, the corresponding CMFB flag in TCSR is set to 1. Note however that comparison is disabled during the T2 state of a TCORB write cycle. The timer output from the TMO pin can be freely controlled by this compare match signal (compare match B) and the settings of bits OS3 and OS2 in TCSR. TCORB is initialized to H'FF.
TCORB_0 4 3 TCORB_1 4 3
Bit Bit Name Initial Value R/W
7
6
5
2
1
0
7
6
5
2
1
0
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
1 R/W
11.3.4
Timer Control Register (TCR)
TCR selects the TCNT clock source and the condition for clearing TCNT, and enables/disables interrupt requests.
Bit Bit Name Initial Value R/W 7 CMIEB 0 R/W 6 CMIEA 0 R/W 5 OVIE 0 R/W 4 CCLR1 0 R/W 3 CCLR0 0 R/W 2 CKS2 0 R/W 1 CKS1 0 R/W 0 CKS0 0 R/W
Bit 7
Bit Name CMIEB
Initial Value 0
R/W R/W
Description Compare Match Interrupt Enable B Selects whether CMFB interrupt requests (CMIB) are enabled or disabled when the CMFB flag in TCSR is set to 1. 0: CMFB interrupt requests (CMIB) are disabled 1: CMFB interrupt requests (CMIB) are enabled
Rev.2.00 Jun. 28, 2007 Page 417 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
Bit 6
Bit Name CMIEA
Initial Value 0
R/W R/W
Description Compare Match Interrupt Enable A Selects whether CMFA interrupt requests (CMIA) are enabled or disabled when the CMFA flag in TCSR is set to 1. 0: CMFA interrupt requests (CMIA) are disabled 1: CMFA interrupt requests (CMIA) are enabled
5
OVIE
0
R/W
Timer Overflow Interrupt Enable Selects whether OVF interrupt requests (OVI) are enabled or disabled when the OVF flag in TCSR is set to 1. 0: OVF interrupt requests (OVI) are disabled 1: OVF interrupt requests (OVI) are enabled
4 3
CCLR1 CCLR0
0 0
R/W R/W
Counter Clear 1 and 0* These bits select the method by which TCNT is cleared. 00: Clearing is disabled 01: Cleared by compare match A 10: Cleared by compare match B 11: Cleared at rising edge (TMRIS in TCCR is cleared to 0) of the external reset input or when the external reset input is high (TMRIS in TCCR is set to 1)
2 1 0 Note: *
CKS2 CKS1 CKS0
0 0 0
R/W R/W R/W
Clock Select 2 to 0* These bits select the clock input to TCNT and count condition. See table 11.2.
To use an external reset or external clock, the DDR and ICR bits in the corresponding pin should be set to 0 and 1, respectively. For details, see section 8, I/O Ports.
Rev.2.00 Jun. 28, 2007 Page 418 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
11.3.5
Timer Counter Control Register (TCCR)
TCCR selects the TCNT internal clock source and controls external reset input.
Bit Bit Name Initial Value R/W 7 0 R/W 6 0 R/W 5 0 R/W 4 0 R/W 3 TMRIS 0 R/W 2 0 R/W 1 ICKS1 0 R/W 0 ICKS0 0 R/W
Bit 7 to 4
Bit Name
Initial Value 0
R/W R/W
Description Reserved These bits are always read as 0. The write value should always be 0.
3
TMRIS
0
R/W
Timer Reset Input Select Selects an external reset input when the CCLR1 and CCLR0 bits in TCR are B'11. 0: Cleared at rising edge of the external reset 1: Cleared when the external reset is high
2
0
R/W
Reserved This bit is always read as 0. The write value should always be 0
1 0
ICKS1 ICKS0
0 0
R/W R/W
Internal Clock Select 1 and 0 These bits in combination with bits CKS2 to CKS0 in TCR select the internal clock. See table 11.2.
Rev.2.00 Jun. 28, 2007 Page 419 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
Table 11.2 Clock Input to TCNT and Count Condition
TCR Channel TMR_0 Bit 2 CKS2 0 0 TCCR Description Clock input prohibited. Uses internal clock. Counts at rising edge of P/8. Uses internal clock. Counts at rising edge of P/2. Uses internal clock. Counts at falling edge of P/8. Uses internal clock. Counts at falling edge of P/2. Uses internal clock. Counts at rising edge of P/64. Uses internal clock. Counts at rising edge of P/32. Uses internal clock. Counts at falling edge of P/64. Uses internal clock. Counts at falling edge of P/32. Uses internal clock. Counts at rising edge of P/8192. Uses internal clock. Counts at rising edge of P/1024. Uses internal clock. Counts at falling edge of P/8192. Uses internal clock. Counts at falling edge of P/1024. Counts at TCNT_1 overflow signal* . Clock input prohibited. Uses internal clock. Counts at rising edge of P/8. Uses internal clock. Counts at rising edge of P/2. Uses internal clock. Counts at falling edge of P/8. Uses internal clock. Counts at falling edge of P/2. Uses internal clock. Counts at rising edge of P/64. Uses internal clock. Counts at rising edge of P/32. Uses internal clock. Counts at falling edge of P/64. Uses internal clock. Counts at falling edge of P/32. Uses internal clock. Counts at rising edge of P/8192. Uses internal clock. Counts at rising edge of P/1024. Uses internal clock. Counts at falling edge of P/8192. Uses internal clock. Counts at falling edge of P/1024. Counts at TCNT_0 compare match A* .
1 1
Bit 1 Bit 0 Bit 1 Bit 0 CKS1 CKS0 ICKS1 ICKS0 0 0 0 1 0 0 1 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1
0
1
0
0 0 1 1
0
1
1
0 0 1 1
1 TMR_1 0 0
0 0 0
0 0 1
0 0 1 1
0
1
0
0 0 1 1
0
1
1
0 0 1 1
1
0
0
Rev.2.00 Jun. 28, 2007 Page 420 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
TCR Channel All Bit 2 CKS2 1 1 1
TCCR Description Uses external clock. Counts at rising edge* . Uses external clock. Counts at falling edge* . Uses external clock. Counts at both rising and falling 2 edges* .
2 2
Bit 1 Bit 0 Bit 1 Bit 0 CKS1 CKS0 ICKS1 ICKS0 0 1 1 1 0 1
Notes: 1. If the clock input of TMR_0 is the TCNT_1 overflow signal and that of TMR_1 is the TCNT_0 compare match signal, no incrementing clock is generated. Do not use this setting. 2. To use the external clock, the DDR and ICR bits in the corresponding pin should be set to 0 and 1, respectively. For details, see section 8, I/O Ports.
11.3.6
Timer Control/Status Register (TCSR)
TCSR displays status flags, and controls compare match output.
* TCSR_0 Bit Bit Name Initial Value R/W * TCSR_1 Bit Bit Name Initial Value R/W 7 CMFB 0 R/(W)* 6 CMFA 0 R/(W)* 5 OVF 0 R/(W)* 4 1 R 3 OS3 0 R/W 2 OS2 0 R/W 1 OS1 0 R/W 0 OS0 0 R/W
7 CMFB 0 R/(W)*
6 CMFA 0 R/(W)*
5 OVF 0 R/(W)*
4 ADTE 0 R/W
3 OS3 0 R/W
2 OS2 0 R/W
1 OS1 0 R/W
0 OS0 0 R/W
Note: * Only 0 can be written to this bit, to clear the flag.
Rev.2.00 Jun. 28, 2007 Page 421 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
* TCSR_0
Bit 7 Bit Name CMFB Initial Value 0 R/W
1
Description [Setting condition] * * When TCNT matches TCORB When writing 0 after reading CMFB = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.) When the DTC is activated by a CMIB interrupt while the DISEL bit in MRB of the DTC is 0 [Clearing conditions]
R/(W)* Compare Match Flag B
* 6 CMFA 0
R/(W)*1 Compare Match Flag A [Setting condition] * * When TCNT matches TCORA When writing 0 after reading CMFA = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.) When the DTC is activated by a CMIA interrupt while the DISEL bit in MRB in the DTC is 0 [Clearing conditions]
* 5 OVF 0
R/(W)*1 Timer Overflow Flag [Setting condition] When TCNT overflows from H'FF to H'00 [Clearing condition] When writing 0 after reading OVF = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.)
4
ADTE
0
R/W
A/D Trigger Enable Selects enabling or disabling of A/D converter start requests by compare match A. 0: A/D converter start requests by compare match A are disabled 1: A/D converter start requests by compare match A are enabled
Rev.2.00 Jun. 28, 2007 Page 422 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
Bit 3 2
Bit Name OS3 OS2
Initial Value 0 0
R/W R/W R/W
Description Output Select 3 and 2*2 These bits select a method of TMO pin output when compare match B of TCORB and TCNT occurs. 00: No change when compare match B occurs 01: 0 is output when compare match B occurs 10: 1 is output when compare match B occurs 11: Output is inverted when compare match B occurs (toggle output)
1 0
OS1 OS0
0 0
R/W R/W
Output Select 1 and 0*2 These bits select a method of TMO pin output when compare match A of TCORA and TCNT occurs. 00: No change when compare match A occurs 01: 0 is output when compare match A occurs 10: 1 is output when compare match A occurs 11: Output is inverted when compare match A occurs (toggle output)
Notes: 1. Only 0 can be written to bits 7 to 5, to clear these flags. 2. Timer output is disabled when bits OS3 to OS0 are all 0. Timer output is 0 until the first compare match occurs after resetting.
* TCSR_1
Bit 7 Bit Name CMFB Initial Value 0 R/W
1
Description
R/(W)* Compare Match Flag B [Setting condition] When TCNT matches TCORB [Clearing conditions] * When writing 0 after reading CMFB = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.) When the DTC is activated by a CMIB interrupt while the DISEL bit in MRB of the DTC is 0
*
Rev.2.00 Jun. 28, 2007 Page 423 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
Bit 6
Bit Name CMFA
Initial Value 0
R/W
1
Description
5
OVF
0
4 3 2
OS3 OS2
1 0 0
1 0
OS1 OS0
0 0
R/(W)* Compare Match Flag A [Setting condition] When TCNT matches TCORA [Clearing conditions] * When writing 0 after reading CMFA = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.) * When the DTC is activated by a CMIA interrupt while the DISEL bit in MRB of the DTC is 0 R/(W)*1 Timer Overflow Flag [Setting condition] When TCNT overflows from H'FF to H'00 [Clearing condition] Cleared by reading OVF when OVF = 1, then writing 0 to OVF (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.) R Reserved This is a read-only bit and cannot be modified. R/W Output Select 3 and 2*2 R/W These bits select a method of TMO pin output when compare match B of TCORB and TCNT occurs. 00: No change when compare match B occurs 01: 0 is output when compare match B occurs 10: 1 is output when compare match B occurs 11: Output is inverted when compare match B occurs (toggle output) R/W Output Select 1 and 0*2 R/W These bits select a method of TMO pin output when compare match A of TCORA and TCNT occurs. 00: No change when compare match A occurs 01: 0 is output when compare match A occurs 10: 1 is output when compare match A occurs 11: Output is inverted when compare match A occurs (toggle output)
Notes: 1. Only 0 can be written to bits 7 to 5, to clear these flags. 2. Timer output is disabled when bits OS3 to OS0 are all 0. Timer output is 0 until the first compare match occurs after resetting.
Rev.2.00 Jun. 28, 2007 Page 424 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
11.4
11.4.1
Operation
Pulse Output
Figure 11.3 shows an example of the 8-bit timer being used to generate a pulse output with a desired duty cycle. The control bits are set as follows: 1. In TCR, clear bit CCLR1 to 0 and set bit CCLR0 to 1 so that TCNT is cleared at a TCORA compare match. 2. In TCSR, set bits OS3 to OS0 to B'0110, causing the output to change to 1 at a TCORA compare match and to 0 at a TCORB compare match. With these settings, the 8-bit timer provides pulses output at a cycle determined by TCORA with a pulse width determined by TCORB. No software intervention is required. The output level of the 8-bit timer holds 0 until the first compare match occurs after a reset.
TCNT H'FF TCORA TCORB H'00 Counter clear
TMO
Figure 11.3 Example of Pulse Output
Rev.2.00 Jun. 28, 2007 Page 425 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
11.4.2
Reset Input
Figure 11.4 shows an example of the 8-bit timer being used to generate a pulse which is output after a desired delay time from a TMRI input. The control bits are set as follows: 1. Set both bits CCLR1 and CCLR0 in TCR to 1 and set the TMRIS bit in TCCR to 1 so that TCNT is cleared at the high level input of the TMRI signal. 2. In TCSR, set bits OS3 to OS0 to B'0110, causing the output to change to 1 at a TCORA compare match and to 0 at a TCORB compare match. With these settings, the 8-bit timer provides pulses output at a desired delay time from a TMRI input determined by TCORA and with a pulse width determined by TCORB and TCORA.
TCORB TCORA TCNT
H'00
TMRI TMO
Figure 11.4 Example of Reset Input
Rev.2.00 Jun. 28, 2007 Page 426 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
11.5
11.5.1
Operation Timing
TCNT Count Timing
Figure 11.5 shows the TCNT count timing for internal clock input. Figure 11.6 shows the TCNT count timing for external clock input. Note that the external clock pulse width must be at least 1.5 states for incrementation at a single edge, and at least 2.5 states for incrementation at both edges. The counter will not increment correctly if the pulse width is less than these values.
P Internal clock TCNT input clock
TCNT
N-1
N
N+1
Figure 11.5 Count Timing for Internal Clock Input at Falling Edge
P External clock input pin TCNT input clock TCNT N-1 N N+1
Figure 11.6 Count Timing for External Clock Input at Falling and Rising Edges 11.5.2 Timing of CMFA and CMFB Setting at Compare Match
The CMFA and CMFB flags in TCSR are set to 1 by a compare match signal generated when the TCOR and TCNT values match. The compare match signal is generated at the last state in which the match is true, just before the timer counter is updated. Therefore, when the TCOR and TCNT values match, the compare match signal is not generated until the next TCNT clock input. Figure 11.7 shows this timing.
Rev.2.00 Jun. 28, 2007 Page 427 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
P TCNT TCOR Compare match signal CMF N N N+1
Figure 11.7 Timing of CMF Setting at Compare Match 11.5.3 Timing of Timer Output at Compare Match
When a compare match signal is generated, the timer output changes as specified by bits OS3 to OS0 in TCSR. Figure 11.8 shows the timing when the timer output is toggled by the compare match A signal.
P Compare match A signal Timer output pin
Figure 11.8 Timing of Toggled Timer Output at Compare Match A 11.5.4 Timing of Counter Clear by Compare Match
TCNT is cleared when compare match A or B occurs, depending on the settings of bits CCLR1 and CCLR0 in TCR. Figure 11.9 shows the timing of this operation.
P Compare match signal TCNT N H'00
Figure 11.9 Timing of Counter Clear by Compare Match
Rev.2.00 Jun. 28, 2007 Page 428 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
11.5.5
Timing of TCNT External Reset
TCNT is cleared at the rising edge or high level of an external reset input, depending on the settings of bits CCLR1 and CCLR0 in TCR. The clear pulse width must be at least 2 states. Figures 11.10 and 11.11 show the timing of this operation.
P External reset input pin Clear signal TCNT N-1 N H'00
Figure 11.10 Timing of Clearance by External Reset (Rising Edge)
P External reset input pin Clear signal TCNT N-1 N H'00
Figure 11.11 Timing of Clearance by External Reset (High Level) 11.5.6 Timing of Overflow Flag (OVF) Setting
The OVF bit in TCSR is set to 1 when TCNT overflows (changes from H'FF to H'00). Figure 11.12 shows the timing of this operation.
P TCNT Overflow signal H'FF H'00
OVF
Figure 11.12 Timing of OVF Setting
Rev.2.00 Jun. 28, 2007 Page 429 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
11.6
Operation with Cascaded Connection
If bits CKS2 to CKS0 in either TCR_0 or TCR_1 are set to B'100, the 8-bit timers of the two channels are cascaded. With this configuration, a single 16-bit timer could be used (16-bit counter mode) or compare matches of the 8-bit channel 0 could be counted by the timer of channel 1 (compare match count mode). 11.6.1 16-Bit Counter Mode
When bits CKS2 to CKS0 in TCR_0 are set to B'100, the timer functions as a single 16-bit timer with channel 0 occupying the upper 8 bits and channel 1 occupying the lower 8 bits. (1) Setting of Compare Match Flags:
* The CMF flag in TCSR_0 is set to 1 when a 16-bit compare match event occurs. * The CMF flag in TCSR_1 is set to 1 when a lower 8-bit compare match event occurs. (2) Counter Clear Specification
* If the CCLR1 and CCLR0 bits in TCR_0 have been set for counter clear at compare match, the 16-bit counter (TCNT_0 and TCNT_1 together) is cleared when a 16-bit compare match event occurs. The 16-bit counter (TCNT0 and TCNT1 together) is cleared even if counter clear by the TMRI0 pin has been set. * The settings of the CCLR1 and CCLR0 bits in TCR_1 are ignored. The lower 8 bits cannot be cleared independently. (3) Pin Output
* Control of output from the TMO0 pin by bits OS3 to OS0 in TCSR_0 is in accordance with the 16-bit compare match conditions. * Control of output from the TMO1 pin by bits OS3 to OS0 in TCSR_1 is in accordance with the lower 8-bit compare match conditions. 11.6.2 Compare Match Count Mode
When bits CKS2 to CKS0 in TCR_1 are set to B'100, TCNT_1 counts compare match A for channel 0. Channels 0 and 1 are controlled independently. Conditions such as setting of the CMF flag, generation of interrupts, output from the TMO pin, and counter clear are in accordance with the settings for each channel.
Rev.2.00 Jun. 28, 2007 Page 430 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
11.7
11.7.1
Interrupt Sources
Interrupt Sources and DTC Activation
There are three interrupt sources for the 8-bit timer (TMR_0 or TMR_1): CMIA, CMIB, and OVI. Their interrupt sources and priorities are shown in table 11.3. Each interrupt source is enabled or disabled by the corresponding interrupt enable bit in TCR or TCSR, and independent interrupt requests are sent for each to the interrupt controller. It is also possible to activate the DTC by means of CMIA and CMIB interrupts. Table 11.3 8-Bit Timer (TMR_0 or TMR_1) Interrupt Sources
Name CMIA0 CMIB0 OVI0 CMIA1 CMIB1 OVI1 Interrupt Source TCORA_0 compare match TCORB_0 compare match TCNT_0 overflow TCORA_1 compare match TCORB_1 compare match TCNT_1 overflow Interrupt Flag CMFA CMFB OVF CMFA CMFB OVF DTC Activation Possible (VNUM = 2'b00) Possible (VNUM = 2'b01) Not possible Possible (VNUM = 2'b10) Possible (VNUM = 2'b11) Not possible Low Low High Priority High
Note: VNUM is an internal signal.
11.7.2
A/D Converter Activation
The A/D converter can be activated only by TMR_0 compare match A. If the ADTE bit in TCSR_0 is set to 1 when the CMFA flag in TCSR_0 is set to 1 by the occurrence of TMR_0 compare match A, a request to start A/D conversion is sent to the A/D converter. If the 8-bit timer conversion start trigger has been selected on the A/D converter side at this time, A/D conversion is started.
Rev.2.00 Jun. 28, 2007 Page 431 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
11.8
11.8.1
Usage Notes
Notes on Setting Cycle
If the compare match is selected for counter clear, TCNT is cleared at the last state in the cycle in which the values of TCNT and TCOR match. TCNT updates the counter value at this last state. Therefore, the counter frequency is obtained by the following formula.
f = / (N + 1 ) f: : N: Counter frequency Operating frequency TCOR value
11.8.2
Conflict between TCNT Write and Clear
If a counter clear signal is generated during the T2 state of a TCNT write cycle, the clear takes priority and the write is not performed as shown in figure 11.13.
TCNT write cycle by CPU T1 T2 P Address TCNT address
Internal write signal Counter clear signal
TCNT
N
H'00
Figure 11.13 Conflict between TCNT Write and Clear
Rev.2.00 Jun. 28, 2007 Page 432 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
11.8.3
Conflict between TCNT Write and Increment
If a TCNT input clock pulse is generated during the T2 state of a TCNT write cycle, the write takes priority and the counter is not incremented as shown in figure 11.14.
TCNT write cycle by CPU T1 T2 P Address Internal write signal TCNT input clock TCNT N Counter write data M TCNT address
Figure 11.14 Conflict between TCNT Write and Increment 11.8.4 Conflict between TCOR Write and Compare Match
If a compare match event occurs during the T2 state of a TCOR write cycle, the TCOR write takes priority and the compare match signal is inhibited as shown in figure 11.15.
TCOR write cycle by CPU T1 T2 P Address Internal write signal TCNT TCOR N N TCOR write data Compare match signal Inhibited N+1 M TCOR address
Figure 11.15 Conflict between TCOR Write and Compare Match
Rev.2.00 Jun. 28, 2007 Page 433 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
11.8.5
Conflict between Compare Matches A and B
If compare match events A and B occur at the same time, the 8-bit timer operates in accordance with the priorities for the output statuses set for compare match A and compare match B, as shown in table 11.4. Table 11.4 Timer Output Priorities
Output Setting Toggle output 1-output 0-output No change Low Priority High
11.8.6
Switching of Internal Clocks and TCNT Operation
TCNT may be incremented erroneously depending on when the internal clock is switched. Table 11.5 shows the relationship between the timing at which the internal clock is switched (by writing to bits CKS1 and CKS0) and the TCNT operation. When the TCNT clock is generated from an internal clock, the rising or falling edge of the internal clock pulse are always monitored. Table 11.5 assumes that the falling edge is selected. If the signal levels of the clocks before and after switching change from high to low as shown in item 3, the change is considered as the falling edge. Therefore, a TCNT clock pulse is generated and TCNT is incremented. This is similar to when the rising edge is selected. The erroneous incrementation of TCNT can also happen when switching between rising and falling edges of the internal clock, and when switching between internal and external clocks.
Rev.2.00 Jun. 28, 2007 Page 434 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
Table 11.5 Switching of Internal Clock and TCNT Operation
No. 1 Timing to Change CKS1 and CKS0 Bits Switching from low to low*
1
TCNT Clock Operation
Clock before switchover Clock after switchover TCNT input clock TCNT N CKS bits changed N+1
2
Switching from low to high*
2
Clock before switchover Clock after switchover TCNT input clock TCNT N N+1 N+2
CKS bits changed
3
Switching from high to low*
3
Clock before switchover Clock after switchover *4 TCNT input clock TCNT N N+1 CKS bits changed N+2
4
Switching from high to high
Clock before switchover Clock after switchover TCNT input clock TCNT N N+1 N+2 CKS bits changed
Notes: 1. 2. 3. 4.
Includes switching from low to stop, and from stop to low. Includes switching from stop to high. Includes switching from high to stop. Generated because the change of the signal levels is considered as a falling edge; TCNT is incremented.
Rev.2.00 Jun. 28, 2007 Page 435 of 666 REJ09B0311-0200
Section 11 8-Bit Timers (TMR)
11.8.7
Mode Setting with Cascaded Connection
If 16-bit counter mode and compare match count mode are specified at the same time, input clocks for TCNT_0 and TCNT_1 are not generated, and the counter stops. Do not specify 16-bit counter mode and compare match count mode simultaneously. 11.8.8 Module Stop State Setting
Operation of the TMR can be disabled or enabled using the module stop control register. The initial setting is for operation of the TMR to be halted. Register access is enabled by clearing module stop state. For details, see section 18, Power-Down States. 11.8.9 Interrupts in Module Stop State
If module stop state is entered when an interrupt has been requested, it will not be possible to clear the CPU interrupt source or the DTC activation source. Interrupts should therefore be disabled before entering module stop state.
Rev.2.00 Jun. 28, 2007 Page 436 of 666 REJ09B0311-0200
Section 12 Watchdog Timer (WDT)
Section 12 Watchdog Timer (WDT)
The watchdog timer (WDT) is an 8-bit timer that outputs an overflow signal (WDTOVF) if a system crash prevents the CPU from writing to the timer counter, thus allowing it to overflow. At the same time, the WDT can also generate an internal reset signal. When this watchdog function is not needed, the WDT can be used as an interval timer. In interval timer operation, an interval timer interrupt is generated each time the counter overflows. Figure 12.1 shows a block diagram of the WDT.
12.1
Features
* Selectable from eight counter input clocks * Switchable between watchdog timer mode and interval timer mode In watchdog timer mode If the counter overflows, the WDT outputs WDTOVF. It is possible to select whether or not the entire LSI is reset at the same time. In interval timer mode If the counter overflows, the WDT generates an interval timer interrupt (WOVI).
Overflow WOVI (interrupt request signal) WDTOVF Internal reset signal* Interrupt control Clock Clock select
Reset control
P/2 P/64 P/128 P/512 P/2048 P/8192 P/32768 P/131072 Internal clocks
RSTCSR
TCNT
TCSR Bus interface
Module bus WDT [Legend] TCSR: Timer control/status register TCNT: Timer counter Reset control/status register RSTCSR:
Note: * An internal reset signal can be generated by the RSTCSR setting.
Figure 12.1 Block Diagram of WDT
Rev.2.00 Jun. 28, 2007 Page 437 of 666 REJ09B0311-0200
Internal bus
Section 12 Watchdog Timer (WDT)
12.2
Input/Output Pin
Table 12.1 shows the WDT pin configuration. Table 12.1 Pin Configuration
Name Watchdog timer overflow Symbol WDTOVF I/O Output Function Outputs a counter overflow signal in watchdog timer mode
12.3
Register Descriptions
The WDT has the following three registers. To prevent accidental overwriting, TCSR, TCNT, and RSTCSR have to be written to in a method different from normal registers. For details, see section 12.6.1, Notes on Register Access. * Timer counter (TCNT) * Timer control/status register (TCSR) * Reset control/status register (RSTCSR) 12.3.1 Timer Counter (TCNT)
TCNT is an 8-bit readable/writable up-counter. TCNT is initialized to H'00 when the TME bit in TCSR is cleared to 0.
Bit Bit Name Initial Value R/W 0 R/W 0 R/W 0 R/W 0 R/W 0 R/W 0 R/W 0 R/W 0 R/W 7 6 5 4 3 2 1 0
Rev.2.00 Jun. 28, 2007 Page 438 of 666 REJ09B0311-0200
Section 12 Watchdog Timer (WDT)
12.3.2
Timer Control/Status Register (TCSR)
TCSR selects the clock source to be input to TCNT, and the timer mode.
Bit Bit Name Initial Value R/W 7 OVF 0 R/(W)* 6 WT/IT 0 R/W 5 TME 0 R/W 4 1 R 3 1 R 2 CKS2 0 R/W 1 CKS1 0 R/W 0 CKS0 0 R/W
Note: * Only 0 can be written to this bit, to clear the flag.
Bit 7
Bit Name OVF
Initial Value 0
R/W
Description
R/(W)* Overflow Flag Indicates that TCNT has overflowed in interval timer mode. Only 0 can be written to this bit, to clear the flag. [Setting condition] When TCNT overflows in interval timer mode (changes from H'FF to H'00) When internal reset request generation is selected in watchdog timer mode, OVF is cleared automatically by the internal reset. [Clearing condition] Cleared by reading TCSR when OVF = 1, then writing 0 to OVF (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.)
6
WT/IT
0
R/W
Timer Mode Select Selects whether the WDT is used as a watchdog timer or interval timer. 0: Interval timer mode When TCNT overflows, an interval timer interrupt (WOVI) is requested. 1: Watchdog timer mode When TCNT overflows, the WDTOVF signal is output.
Rev.2.00 Jun. 28, 2007 Page 439 of 666 REJ09B0311-0200
Section 12 Watchdog Timer (WDT)
Bit 5
Bit Name TME
Initial Value 0
R/W R/W
Description Timer Enable When this bit is set to 1, TCNT starts counting. When this bit is cleared, TCNT stops counting and is initialized to H'00.
4, 3 2 1 0
CKS2 CKS1 CKS0
All 1 0 0 0
R R/W R/W R/W
Reserved These are read-only bits and cannot be modified. Clock Select 2 to 0 Select the clock source to be input to TCNT. The overflow cycle for P = 20 MHz is indicated in parentheses. 000: Clock P/2 (cycle: 25.6 s) 001: Clock P/64 (cycle: 819.2 s) 010: Clock P/128 (cycle: 1.6 ms) 011: Clock P/512 (cycle: 6.6 ms) 100: Clock P/2048 (cycle: 26.2 ms) 101: Clock P/8192 (cycle: 104.9 ms) 110: Clock P/32768 (cycle: 419.4 ms) 111: Clock P/131072 (cycle: 1.68 s)
Note:
*
Only 0 can be written to this bit, to clear the flag.
Rev.2.00 Jun. 28, 2007 Page 440 of 666 REJ09B0311-0200
Section 12 Watchdog Timer (WDT)
12.3.3
Reset Control/Status Register (RSTCSR)
RSTCSR controls the generation of the internal reset signal when TCNT overflows, and selects the type of internal reset signal. RSTCSR is initialized to H'1F by a reset signal from the RES pin, but not by the WDT internal reset signal caused by WDT overflows.
Bit Bit Name Initial Value R/W 7 WOVF 0 R/(W)* 6 RSTE 0 R/W 5 0 R/W 4 1 R 3 1 R 2 1 R 1 1 R 0 1 R
Note: * Only 0 can be written to this bit, to clear the flag.
Bit 7
Bit Name WOVF
Initial Value 0
R/W
Description
R/(W)* Watchdog Timer Overflow Flag This bit is set when TCNT overflows in watchdog timer mode. This bit cannot be set in interval timer mode, and only 0 can be written. [Setting condition] When TCNT overflows (changed from H'FF to H'00) in watchdog timer mode [Clearing condition] Reading RSTCSR when WOVF = 1, and then writing 0 to WOVF
6
RSTE
0
R/W
Reset Enable Specifies whether or not this LSI is internally reset if TCNT overflows during watchdog timer operation. 0: LSI is not reset even if TCNT overflows (Though this LSI is not reset, TCNT and TCSR in WDT are reset) 1: LSI is reset if TCNT overflows
5
0
R/W
Reserved Although this bit is readable/writable, reading from or writing to this bit does not affect operation.
4 to 0 Note: *
All 1
R
Reserved These are read-only bits and cannot be modified.
Only 0 can be written to this bit, to clear the flag.
Rev.2.00 Jun. 28, 2007 Page 441 of 666 REJ09B0311-0200
Section 12 Watchdog Timer (WDT)
12.4
12.4.1
Operation
Watchdog Timer Mode
To use the WDT in watchdog timer mode, set both the WT/IT and TME bits in TCSR to 1. During watchdog timer operation, if TCNT overflows without being rewritten because of a system crash or other error, the WDTOVF signal is output. This ensures that TCNT does not overflow while the system is operating normally. Software must prevent TCNT overflows by rewriting the TCNT value (normally H'00 is written) before overflow occurs. This WDTOVF signal can be used to reset the LSI internally in watchdog timer mode. If TCNT overflows when the RSTE bit in RSTCSR is set to 1, a signal that resets this LSI internally is generated at the same time as the WDTOVF signal. If a reset caused by a signal input to the RES pin occurs at the same time as a reset caused by a WDT overflow, the RES pin reset has priority and the WOVF bit in RSTCSR is cleared to 0. The WDTOVF signal is output for 133 states with P when RSTE = 1 in RSTCSR, and for 130 states with P when RSTE = 0 in RSTCSR. The internal reset signal is output for 519 states with P. When the RSTE bit = 1, an internal reset signal is generated. As this signal resets the system clock control register (SCKCR), the magnification power of P to the input clock becomes the initial value. When the RSTE bit = 0, no internal reset signal is generated. Therefore, the setting of SCKCR is retained and the magnification power of P to the input clock does not change. When TCNT overflows in watchdog timer mode, the WOVF bit in RSTCSR is set to 1. If TCNT overflows when the RSTE bit in RSTCSR is set to 1, an internal reset signal is generated for the entire LSI.
Rev.2.00 Jun. 28, 2007 Page 442 of 666 REJ09B0311-0200
Section 12 Watchdog Timer (WDT)
TCNT value Overflow H'FF
H'00 WT/IT = 1 TME = 1 H'00 written to TCNT WOVF = 1 WDTOVF and internal reset are generated WT/IT = 1 H'00 written TME = 1 to TCNT
Time
WDTOVF signal
133 states*2
Internal reset signal*1 519 states Notes: 1. If TCNT overflows when the RSTE bit is set to 1, an internal reset signal is generated. 2. 130 states when the RSTE bit is cleared to 0.
Figure 12.2 Operation in Watchdog Timer Mode
Rev.2.00 Jun. 28, 2007 Page 443 of 666 REJ09B0311-0200
Section 12 Watchdog Timer (WDT)
12.4.2
Interval Timer Mode
To use the WDT as an interval timer, set the WT/IT bit to 0 and the TME bit to 1 in TCSR. When the WDT is used as an interval timer, an interval timer interrupt (WOVI) is generated each time the TCNT overflows. Therefore, an interrupt can be generated at intervals. When the TCNT overflows in interval timer mode, an interval timer interrupt (WOVI) is requested at the same time the OVF bit in the TCSR is set to 1.
TCNT value H'FF Overflow Overflow Overflow Overflow
H'00 WT/IT = 0 TME = 1 WOVI WOVI WOVI WOVI
Time
WOVI: Interval timer interrupt request
Figure 12.3 Operation in Interval Timer Mode
12.5
Interrupt Source
During interval timer mode operation, an overflow generates an interval timer interrupt (WOVI). The interval timer interrupt is requested whenever the OVF flag is set to 1 in TCSR. The OVF flag must be cleared to 0 in the interrupt handling routine. Table 12.2 WDT Interrupt Source
Name WOVI Interrupt Source TCNT overflow Interrupt Flag OVF DTC Activation Impossible
Rev.2.00 Jun. 28, 2007 Page 444 of 666 REJ09B0311-0200
Section 12 Watchdog Timer (WDT)
12.6
12.6.1
Usage Notes
Notes on Register Access
The watchdog timer's TCNT, TCSR, and RSTCSR registers differ from other registers in being more difficult to write to. The procedures for writing to and reading these registers are given below. (1) Writing to TCNT, TCSR, and RSTCSR
TCNT and TCSR must be written to by a word transfer instruction. They cannot be written to by a byte transfer instruction. For writing, TCNT and TCSR are assigned to the same address. Accordingly, perform data transfer as shown in figure 12.4. The transfer instruction writes the lower byte data to TCNT or TCSR. To write to RSTCSR, execute a word transfer instruction for address H'FFA6. A byte transfer instruction cannot be used to write to RSTCSR. The method of writing 0 to the WOVF bit in RSTCSR differs from that of writing to the RSTE bit in RSTCSR. Perform data transfer as shown in figure 12.4. At data transfer, the transfer instruction clears the WOVF bit to 0, but has no effect on the RSTE bit. To write to the RSTE bit, perform data transfer as shown in figure 12.4. In this case, the transfer instruction writes the value in bit 6 of the lower byte to the RSTE bit, but has no effect on the WOVF bit.
TCNT write or writing to the RSTE bit in RSTCSR: 15 Address: H'FFA4 (TCNT) H'FFA6 (RSTCSR) 8 H'5A 7 Write data 0
TCSR write: Address: H'FFA4 (TCSR) 15 H'A5 8 7 Write data 0
Writing 0 to the WOVF bit in RSTCSR: 15 Address: H'FFA6 (RSTCSR)
8 H'A5
7 H'00
0
Figure 12.4 Writing to TCNT, TCSR, and RSTCSR
Rev.2.00 Jun. 28, 2007 Page 445 of 666 REJ09B0311-0200
Section 12 Watchdog Timer (WDT)
(2)
Reading from TCNT, TCSR, and RSTCSR
These registers can be read from in the same way as other registers. For reading, TCSR is assigned to address H'FFA4, TCNT to address H'FFA5, and RSTCSR to address H'FFA7. 12.6.2 Conflict between Timer Counter (TCNT) Write and Increment
If a TCNT clock pulse is generated during the T2 state of a TCNT write cycle, the write takes priority and the timer counter is not incremented. Figure 12.5 shows this operation.
TCNT write cycle T2 T1 P Address
Internal write signal
TCNT input clock
TCNT
N Counter write data
M
Figure 12.5 Conflict between TCNT Write and Increment 12.6.3 Changing Values of Bits CKS2 to CKS0
If bits CKS2 to CKS0 in TCSR are written to while the WDT is operating, errors could occur in the incrementation. The watchdog timer must be stopped (by clearing the TME bit to 0) before the values of bits CKS2 to CKS0 are changed. 12.6.4 Switching between Watchdog Timer Mode and Interval Timer Mode
If the timer mode is switched from watchdog timer mode to interval timer mode while the WDT is operating, errors could occur in the incrementation. The watchdog timer must be stopped (by clearing the TME bit to 0) before switching the timer mode.
Rev.2.00 Jun. 28, 2007 Page 446 of 666 REJ09B0311-0200
Section 12 Watchdog Timer (WDT)
12.6.5
Internal Reset in Watchdog Timer Mode
This LSI is not reset internally if TCNT overflows while the RSTE bit is cleared to 0 during watchdog timer mode operation, but TCNT and TCSR of the WDT are reset. TCNT, TCSR, and RSTCR cannot be written to while the WDTOVF signal is low. Also note that a read of the WOVF flag is not recognized during this period. To clear the WOVF flag, therefore, read TCSR after the WDTOVF signal goes high, and then write 0 to the WOVF flag. 12.6.6 System Reset by WDTOVF Signal
If the WDTOVF signal is input to the RES pin, this LSI will not be initialized correctly. Make sure that the WDTOVF signal is not input logically to the RES pin. To reset the entire system by means of the WDTOVF signal, use a circuit like that shown in figure 12.6.
This LSI Reset input RES
Reset signal to entire system
WDTOVF
Figure 12.6 Circuit for System Reset by WDTOVF Signal (Example) 12.6.7 Transition to Watchdog Timer Mode or Software Standby Mode
When the WDT operates in watchdog timer mode, a transition to software standby mode is not made even when the SLEEP instruction is executed when the SSBY bit in SBYCR is set to 1. Instead, a transition to sleep mode is made. To transit to software standby mode, the SLEEP instruction must be executed after halting the WDT (clearing the TME bit to 0). When the WDT operates in interval timer mode, a transition to software standby mode is made through execution of the SLEEP instruction when the SSBY bit in SBYCR is set to 1.
Rev.2.00 Jun. 28, 2007 Page 447 of 666 REJ09B0311-0200
Section 12 Watchdog Timer (WDT)
Rev.2.00 Jun. 28, 2007 Page 448 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Section 13 Serial Communication Interface (SCI)
This LSI has four independent serial communication interface (SCI) channels. The SCI can handle both asynchronous and clocked synchronous serial communication. Asynchronous serial data communication can be carried out with standard asynchronous communication chips such as a Universal Asynchronous Receiver/Transmitter (UART) or Asynchronous Communication Interface Adapter (ACIA). A function is also provided for serial communication between processors (multiprocessor communication function). The SCI also supports the smart card (IC card) interface supporting ISO/IEC 7816-3 (Identification Card) as an extended asynchronous communication mode. Figure 13.1 shows a block diagram of the SCI.
13.1
Features
* Choice of asynchronous or clocked synchronous serial communication mode * Full-duplex communication capability The transmitter and receiver are mutually independent, enabling transmission and reception to be executed simultaneously. Double-buffering is used in both the transmitter and the receiver, enabling continuous transmission and continuous reception of serial data. * On-chip baud rate generator allows any bit rate to be selected The external clock can be selected as a transfer clock source (except for the smart card interface). * Choice of LSB-first or MSB-first transfer (except in the case of asynchronous mode 7-bit data) * Four interrupt sources The interrupt sources are transmit-end, transmit-data-empty, receive-data-full, and receive error. The transmit-data-empty and receive-data-full interrupt sources can activate the DTC. * Module stop state specifiable Asynchronous Mode: * * * * * Data length: 7 or 8 bits Stop bit length: 1 or 2 bits Parity: Even, odd, or none Receive error detection: Parity, overrun, and framing errors Break detection: Break can be detected by reading the RxD pin level directly in case of a framing error
Rev.2.00 Jun. 28, 2007 Page 449 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
* Average transfer rate generator (SCI_2 only) 10.667-MHz operation: 460.606 kbps or 115.152 kbps can be selected 16-MHz operation: 720 kbps, 460.784 kbps, or 115.196 kbps can be selected 32-MHz operation: 720 kbps Clocked Synchronous Mode: * Data length: 8 bits * Receive error detection: Overrun errors Smart Card Interface: * An error signal can be automatically transmitted on detection of a parity error during reception * Data can be automatically re-transmitted on receiving an error signal during transmission * Both direct convention and inverse convention are supported
Module data bus
RDR
TDR
SCMR SSR SCR
BRR P Baud rate generator P/4 P/16
RxD
RSR
TSR
SMR Transmission/ reception control
P/64 Clock Average transfer rate generator (SCI_2) At 10.667-MHz operation: 115.152 kbps 460.606 kbps At 16-MHz operation: 115.196 kbps 460.784 kbps 720 kbps At 32-MHz operation: 720 kbps
TxD Parity check SCK
Parity generation
External clock TEI TXI RXI ERI SCR: SSR: SCMR: BRR: SEMR:
[Legend] RSR: Receive shift register RDR: Receive data register TSR: Transmit shift register TDR: Transmit data register SMR: Serial mode register
Serial control register Serial status register Smart card mode register Bit rate register Serial extended mode register (available only for SCI_2)
Figure 13.1 Block Diagram of SCI
Rev.2.00 Jun. 28, 2007 Page 450 of 666 REJ09B0311-0200
Internal data bus
Bus interface
Section 13 Serial Communication Interface (SCI)
13.2
Input/Output Pins
Table 13.1 lists the pin configuration of the SCI. Table 13.1 Pin Configuration
Channel 0 Pin Name* SCK0 RxD0 TxD0 1 SCK1 RxD1 TxD1 2 SCK2 RxD2 TxD2 4 SCK4 RxD4 TxD4 Note: * I/O I/O Input Output I/O Input Output I/O Input Output I/O Input Output Function Channel 0 clock input/output Channel 0 receive data input Channel 0 transmit data output Channel 1 clock input/output Channel 1 receive data input Channel 1 transmit data output Channel 2 clock input/output Channel 2 receive data input Channel 2 transmit data output Channel 4 clock input/output Channel 4 receive data input Channel 4 transmit data output
Pin names SCK, RxD, and TxD are used in the text for all channels, omitting the channel designation.
Rev.2.00 Jun. 28, 2007 Page 451 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.3
Register Descriptions
The SCI has the following registers. Some bits in the serial mode register (SMR), serial status register (SSR), and serial control register (SCR) have different functions in different modesnormal serial communication interface mode and smart card interface mode; therefore, the bits are described separately for each mode in the corresponding register sections. Channel 0: * * * * * * * * * Receive shift register_0 (RSR_0) Transmit shift register_0 (TSR_0) Receive data register_0 (RDR_0) Transmit data register_0 (TDR_0) Serial mode register_0 (SMR_0) Serial control register_0 (SCR_0) Serial status register_0 (SSR_0) Smart card mode register_0 (SCMR_0) Bit rate register_0 (BRR_0)
Channel 1: * * * * * * * * * Receive shift register_1 (RSR_1) Transmit shift register_1 (TSR_1) Receive data register_1 (RDR_1) Transmit data register_1 (TDR_1) Serial mode register_1 (SMR_1) Serial control register_1 (SCR_1) Serial status register_1 (SSR_1) Smart card mode register_1 (SCMR_1) Bit rate register_1 (BRR_1)
Rev.2.00 Jun. 28, 2007 Page 452 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Channel 2: * * * * * * * * * * Receive shift register_2 (RSR_2) Transmit shift register_2 (TSR_2) Receive data register_2 (RDR_2) Transmit data register_2 (TDR_2) Serial mode register_2 (SMR_2) Serial control register_2 (SCR_2) Serial status register_2 (SSR_2) Smart card mode register_2 (SCMR_2) Bit rate register_2 (BRR_2) Serial extended mode register_2 (SEMR_2) (SCI_2 only)
Channel 4: * * * * * * * * * Receive shift register_4 (RSR_4) Transmit shift register_4 (TSR_4) Receive data register_4 (RDR_4) Transmit data register_4 (TDR_4) Serial mode register_4 (SMR_4) Serial control register_4 (SCR_4) Serial status register_4 (SSR_4) Smart card mode register_4 (SCMR_4) Bit rate register_4 (BRR_4)
Rev.2.00 Jun. 28, 2007 Page 453 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.3.1
Receive Shift Register (RSR)
RSR is a shift register which is used to receive serial data input from the RxD pin and converts it into parallel data. When one frame of data has been received, it is transferred to RDR automatically. RSR cannot be directly accessed by the CPU. 13.3.2 Receive Data Register (RDR)
RDR is an 8-bit register that stores receive data. When the SCI has received one frame of serial data, it transfers the received serial data from RSR to RDR where it is stored. This allows RSR to receive the next data. Since RSR and RDR function as a double buffer in this way, continuous receive operations can be performed. After confirming that the RDRF bit in SSR is set to 1, read RDR only once. RDR cannot be written to by the CPU.
Bit Bit Name Initial Value R/W 0 R 0 R 0 R 0 R 0 R 0 R 0 R 0 R 7 6 5 4 3 2 1 0
13.3.3
Transmit Data Register (TDR)
TDR is an 8-bit register that stores transmit data. When the SCI detects that TSR is empty, it transfers the transmit data written in TDR to TSR and starts transmission. The double-buffered structures of TDR and TSR enables continuous serial transmission. If the next transmit data has already been written to TDR when one frame of data is transmitted, the SCI transfers the written data to TSR to continue transmission. Although TDR can be read from or written to by the CPU at all times, to achieve reliable serial transmission, write transmit data to TDR for only once after confirming that the TDRE bit in SSR is set to 1.
Bit Bit Name Initial Value R/W 1 R/W 1 R/W 1 R/W 1 R/W 1 R/W 1 R/W 1 R/W 1 R/W 7 6 5 4 3 2 1 0
Rev.2.00 Jun. 28, 2007 Page 454 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.3.4
Transmit Shift Register (TSR)
TSR is a shift register that transmits serial data. To perform serial data transmission, the SCI first automatically transfers transmit data from TDR to TSR, and then sends the data to the TxD pin. TSR cannot be directly accessed by the CPU. 13.3.5 Serial Mode Register (SMR)
SMR is used to set the SCI's serial transfer format and select the baud rate generator clock source. Some bits in SMR have different functions in normal mode and smart card interface mode. * When SMIF in SCMR = 0
Bit Bit Name Initial Value R/W 7 C/A 0 R/W 6 CHR 0 R/W 5 PE 0 R/W 4 O/E 0 R/W 3 STOP 0 R/W 2 MP 0 R/W 1 CKS1 0 R/W 0 CKS0 0 R/W
* When SMIF in SCMR = 1
Bit Bit Name Initial Value R/W 7 GM 0 R/W 6 BLK 0 R/W 5 PE 0 R/W 4 O/E 0 R/W 3 BCP1 0 R/W 2 BCP0 0 R/W 1 CKS1 0 R/W 0 CKS0 0 R/W
Bit Functions in Normal Serial Communication Interface Mode (When SMIF in SCMR = 0):
Bit 7 Bit Name C/A Initial Value 0 R/W R/W Description Communication Mode 0: Asynchronous mode 1: Clocked synchronous mode 6 CHR 0 R/W Character Length (valid only in asynchronous mode) 0: Selects 8 bits as the data length. 1: Selects 7 bits as the data length. LSB-first is fixed and the MSB (bit 7) in TDR is not transmitted in transmission. In clocked synchronous mode, a fixed data length of 8 bits is used.
Rev.2.00 Jun. 28, 2007 Page 455 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Bit 5
Bit Name PE
Initial Value 0
R/W R/W
Description Parity Enable (valid only in asynchronous mode) When this bit is set to 1, the parity bit is added to transmit data before transmission, and the parity bit is checked in reception. For a multiprocessor format, parity bit addition and checking are not performed regardless of the PE bit setting.
4
O/E
0
R/W
Parity Mode (valid only when the PE bit is 1 in asynchronous mode) 0: Selects even parity. 1: Selects odd parity.
3
STOP
0
R/W
Stop Bit Length (valid only in asynchronous mode) Selects the stop bit length in transmission. 0: 1 stop bit 1: 2 stop bits In reception, only the first stop bit is checked. If the second stop bit is 0, it is treated as the start bit of the next transmit frame.
2
MP
0
R/W
Multiprocessor Mode (valid only in asynchronous mode) When this bit is set to 1, the multiprocessor function is enabled. The PE bit and O/E bit settings are invalid in multiprocessor mode.
1 0
CKS1 CKS0
0 0
R/W R/W
Clock Select 1, 0 These bits select the clock source for the baud rate generator. 00: P clock (n = 0) 01: P/4 clock (n = 1) 10: P/16 clock (n = 2) 11: P/64 clock (n = 3) For the relation between the settings of these bits and the baud rate, see section 13.3.9, Bit Rate Register (BRR). n is the decimal display of the value of n in BRR (see section 13.3.9, Bit Rate Register (BRR)).
Rev.2.00 Jun. 28, 2007 Page 456 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Bit Functions in Smart Card Interface Mode (When SMIF in SCMR = 1):
Bit 7 Bit Name GM Initial Value 0 R/W R/W Description GSM Mode Setting this bit to 1 allows GSM mode operation. In GSM mode, the TEND set timing is put forward to 11.0 etu from the start and the clock output control function is appended. For details, see sections 13.7.6, Data Transmission (Except in Block Transfer Mode) and 13.7.8, Clock Output Control. 6 BLK 0 R/W Setting this bit to 1 allows block transfer mode operation. For details, see section 13.7.3, Block Transfer Mode. Parity Enable (valid only in asynchronous mode) When this bit is set to 1, the parity bit is added to transmit data before transmission, and the parity bit is checked in reception. Set this bit to 1 in smart card interface mode. 4 O/E 0 R/W Parity Mode (valid only when the PE bit is 1 in asynchronous mode) 0: Selects even parity 1: Selects odd parity For details on the usage of this bit in smart card interface mode, see section 13.7.2, Data Format (Except in Block Transfer Mode). 3 2 BCP1 BCP0 0 0 R/W R/W Basic Clock Pulse 1,0 These bits select the number of basic clock cycles in a 1-bit data transfer time in smart card interface mode. 00: 32 clock cycles (S = 32) 01: 64 clock cycles (S = 64) 10: 372 clock cycles (S = 372) 11: 256 clock cycles (S = 256) For details, see section 13.7.4, Receive Data Sampling Timing and Reception Margin. S is described in section 13.3.9, Bit Rate Register (BRR).
5
PE
0
R/W
Rev.2.00 Jun. 28, 2007 Page 457 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Bit 1 0
Bit Name CKS1 CKS0
Initial Value 0 0
R/W R/W R/W
Description Clock Select 1,0 These bits select the clock source for the baud rate generator. 00: P clock (n = 0) 01: P/4 clock (n = 1) 10: P/16 clock (n = 2) 11: P/64 clock (n = 3) For the relation between the settings of these bits and the baud rate, see section 13.3.9, Bit Rate Register (BRR). n is the decimal display of the value of n in BRR (see section 13.3.9, Bit Rate Register (BRR)).
Note:
etu (Elementary Time Unit): 1-bit transfer time
13.3.6
Serial Control Register (SCR)
SCR is a register that enables/disables the following SCI transfer operations and interrupt requests, and selects the transfer clock source. For details on interrupt requests, see section 13.8, Interrupt Sources. Some bits in SCR have different functions in normal mode and smart card interface mode. * When SMIF in SCMR = 0
Bit Bit Name Initial Value R/W 7 TIE 0 R/W 6 RIE 0 R/W 5 TE 0 R/W 4 RE 0 R/W 3 MPIE 0 R/W 2 TEIE 0 R/W 1 CKE1 0 R/W 0 CKE0 0 R/W
* When SMIF in SCMR = 1
Bit Bit Name Initial Value R/W 7 TIE 0 R/W 6 RIE 0 R/W 5 TE 0 R/W 4 RE 0 R/W 3 MPIE 0 R/W 2 TEIE 0 R/W 1 CKE1 0 R/W 0 CKE0 0 R/W
Rev.2.00 Jun. 28, 2007 Page 458 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Bit Functions in Normal Serial Communication Interface Mode (When SMIF in SCMR = 0):
Bit 7 Bit Name TIE Initial Value 0 R/W R/W Description Transmit Interrupt Enable When this bit is set to 1, a TXI interrupt request is enabled. A TXI interrupt request can be cancelled by reading 1 from the TDRE flag and then clearing the flag to 0, or by clearing the TIE bit to 0. 6 RIE 0 R/W Receive Interrupt Enable When this bit is set to 1, RXI and ERI interrupt requests are enabled. RXI and ERI interrupt requests can be cancelled by reading 1 from the RDRF, FER, PER, or ORER flag and then clearing the flag to 0, or by clearing the RIE bit to 0. 5 TE 0 R/W Transmit Enable When this bit is set to 1, transmission is enabled. Under this condition, serial transmission is started by writing transmit data to TDR, and clearing the TDRE flag in SSR to 0. Note that SMR should be set prior to setting the TE bit to 1 in order to designate the transmission format. If transmission is halted by clearing this bit to 0, the TDRE flag in SSR is fixed 1. 4 RE 0 R/W Receive Enable When this bit is set to 1, reception is enabled. Under this condition, serial reception is started by detecting the start bit in asynchronous mode or the synchronous clock input in clocked synchronous mode. Note that SMR should be set prior to setting the RE bit to 1 in order to designate the reception format. Even if reception is halted by clearing this bit to 0, the RDRF, FER, PER, and ORER flags are not affected and the previous value is retained.
Rev.2.00 Jun. 28, 2007 Page 459 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Bit 3
Bit Name MPIE
Initial Value 0
R/W R/W
Description Multiprocessor Interrupt Enable (valid only when the MP bit in SMR is 1 in asynchronous mode) When this bit is set to 1, receive data in which the multiprocessor bit is 0 is skipped, and setting of the RDRF, FER, and ORER status flags in SSR is disabled. On receiving data in which the multiprocessor bit is 1, this bit is automatically cleared and normal reception is resumed. For details, see section 13.5, Multiprocessor Communication Function. When receive data including MPB = 0 in SSR is being received, transfer of the received data from RSR to RDR, detection of reception errors, and the settings of RDRF, FER, and ORER flags in SSR are not performed. When receive data including MPB = 1 is received, the MPB bit in SSR is set to 1, the MPIE bit is automatically cleared to 0, and RXI and ERI interrupt requests (in the case where the TIE and RIE bits in SCR are set to 1) and setting of the FER and ORER flags are enabled.
2
TEIE
0
R/W
Transmit End Interrupt Enable When this bit is set to 1, a TEI interrupt request is enabled. A TEI interrupt request can be cancelled by reading 1 from the TDRE flag and then clearing the flag to 0 in order to clear the TEND flag to 0, or by clearing the TEIE bit to 0.
Rev.2.00 Jun. 28, 2007 Page 460 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Bit 1 0
Bit Name CKE1 CKE0
Initial Value 0 0
R/W R/W R/W
Description Clock Enable 1, 0 These bits select the clock source and SCK pin function. * Asynchronous mode (SCK pin functions as I/O port.) 01: On-chip baud rate generator (Outputs a clock with the same frequency as the bit rate from the SCK pin.) 1X: External clock (Inputs a clock with a frequency 16 times the bit rate from the SCK pin.) * Clocked synchronous mode (SCK pin functions as clock output.) 1X: External clock (SCK pin functions as clock input.) 0X: Internal clock 00: On-chip baud rate generator
Note: X: Don't care
Bit Functions in Smart Card Interface Mode (When SMIF in SCMR = 1):
Bit 7 Bit Name TIE Initial Value 0 R/W R/W Description Transmit Interrupt Enable When this bit is set to 1,a TXI interrupt request is enabled. A TXI interrupt request can be cancelled by reading 1 from the TDRE flag and then clearing the flag to 0, or by clearing the TIE bit to 0. 6 RIE 0 R/W Receive Interrupt Enable When this bit is set to 1, RXI and ERI interrupt requests are enabled. RXI and ERI interrupt requests can be cancelled by reading 1 from the RDRF, FER, PER, or ORER flag and then clearing the flag to 0, or by clearing the RIE bit to 0.
Rev.2.00 Jun. 28, 2007 Page 461 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Bit 5
Bit Name TE
Initial Value 0
R/W R/W
Description Transmit Enable When this bit is set to 1, transmission is enabled. Under this condition, serial transmission is started by writing transmit data to TDR, and clearing the TDRE flag in SSR to 0. Note that SMR should be set prior to setting the TE bit to 1 in order to designate the transmission format. If transmission is halted by clearing this bit to 0, the TDRE flag in SSR is fixed 1.
4
RE
0
R/W
Receive Enable When this bit is set to 1, reception is enabled. Under this condition, serial reception is started by detecting the start bit in asynchronous mode or the synchronous clock input in clocked synchronous mode. Note that SMR should be set prior to setting the RE bit to 1 in order to designate the reception format. Even if reception is halted by clearing this bit to 0, the RDRF, FER, PER, and ORER flags are not affected and the previous value is retained.
3
MPIE
0
R/W
Multiprocessor Interrupt Enable (valid only when the MP bit in SMR is 1 in asynchronous mode) Write 0 to this bit in smart card interface mode. Transmit End Interrupt Enable Write 0 to this bit in smart card interface mode. Clock Enable 1, 0 These bits control the clock output from the SCK pin. In GSM mode, clock output can be dynamically switched. For details, see section 13.7.8, Clock Output Control. * When GM in SMR = 0 00: Output disabled (SCK pin functions as I/O port.) 01: Clock output 1X: Reserved * When GM in SMR = 1 00: Output fixed low 01: Clock output 10: Output fixed high 11: Clock output
2 1 0
TEIE CKE1 CKE0
0 0 0
R/W R/W R/W
Rev.2.00 Jun. 28, 2007 Page 462 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.3.7
Serial Status Register (SSR)
SSR is a register containing status flags of the SCI and multiprocessor bits for transfer. TDRE, RDRF, ORER, PER, and FER can only be cleared. Some bits in SSR have different functions in normal mode and smart card interface mode. * When SMIF in SCMR = 0
Bit Bit Name Initial Value R/W 7 TDRE 1 R/(W)* 6 RDRF 0 R/(W)* 5 ORER 0 R/(W)* 4 FRE 0 R/(W)* 3 PER 0 R/(W)* 2 TEND 1 R 1 MPB 0 R 0 MPBT 0 R/W
Note: * Only 0 can be written, to clear the flag.
* When SMIF in SCMR = 1
Bit Bit Name Initial Value R/W 7 TDRE 1 R/(W)* 6 RDRF 0 R/(W)* 5 ORER 0 R/(W)* 4 ERS 0 R/(W)* 3 PER 0 R/(W)* 2 TEND 1 R 1 MPB 0 R 0 MPBT 0 R/W
Note: * Only 0 can be written, to clear the flag.
Bit Functions in Normal Serial Communication Interface Mode (When SMIF in SCMR = 0):
Bit 7 Bit Name TDRE Initial Value 1 R/W Description Indicates whether TDR contains transmit data. [Setting conditions] * * * When the TE bit in SCR is 0 When data is transferred from TDR to TSR When 0 is written to TDRE after reading TDRE = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.) When a TXI interrupt request is issued allowing DTC to write data to TDR
R/(W)* Transmit Data Register Empty
[Clearing conditions]
*
Rev.2.00 Jun. 28, 2007 Page 463 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Bit 6
Bit Name RDRF
Initial Value 0
R/W
Description Indicates whether receive data is stored in RDR. [Setting condition] * When serial reception ends normally and receive data is transferred from RSR to RDR When 0 is written to RDRF after reading RDRF = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.) When an RXI interrupt request is issued allowing DTC to read data from RDR
R/(W)* Receive Data Register Full
[Clearing conditions] *
*
The RDRF flag is not affected and retains its previous value when the RE bit in SCR is cleared to 0. Note that when the next serial reception is completed while the RDRF flag is being set to 1, an overrun error occurs and the received data is lost. 5 ORER 0 R/(W)* Overrun Error Indicates that an overrun error has occurred during reception and the reception ends abnormally. [Setting condition] When the next serial reception is completed while RDRF = 1 In RDR, receive data prior to an overrun error occurrence is retained, but data received after the overrun error occurrence is lost. When the ORER flag is set to 1, subsequent serial reception cannot be performed. Note that, in clocked synchronous mode, serial transmission also cannot continue. [Clearing condition] * When 0 is written to ORER after reading ORER = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.) Even when the RE bit in SCR is cleared, the ORER flag is not affected and retains its previous value. *
Rev.2.00 Jun. 28, 2007 Page 464 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Bit 4
Bit Name FER
Initial Value 0
R/W
Description
3
PER
0
R/(W)* Framing Error Indicates that a framing error has occurred during reception in asynchronous mode and the reception ends abnormally. [Setting condition] * When the stop bit is 0 In 2-stop-bit mode, only the first stop bit is checked whether it is 1 but the second stop bit is not checked. Note that receive data when the framing error occurs is transferred to RDR, however, the RDRF flag is not set. In addition, when the FER flag is being set to 1, the subsequent serial reception cannot be performed. In clocked synchronous mode, serial transmission also cannot continue. [Clearing condition] * When 0 is written to FER after reading FER = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.) Even when the RE bit in SCR is cleared, the FER flag is not affected and retains its previous value. R/(W)* Parity Error Indicates that a parity error has occurred during reception in asynchronous mode and the reception ends abnormally. [Setting condition] * When a parity error is detected during reception Receive data when the parity error occurs is transferred to RDR, however, the RDRF flag is not set. Note that when the PER flag is being set to 1, the subsequent serial reception cannot be performed. In clocked synchronous mode, serial transmission also cannot continue. [Clearing condition] * When 0 is written to PER after reading PER = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.) Even when the RE bit in SCR is cleared, the PER bit is not affected and retains its previous value.
Rev.2.00 Jun. 28, 2007 Page 465 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Bit 2
Bit Name TEND
Initial Value 1
R/W R
Description Transmit End [Setting conditions] * * When the TE bit in SCR is 0 When TDRE = 1 at transmission of the last bit of a transmit character When 0 is written to TDRE after reading TDRE = 1 When a TXI interrupt request is issued allowing DTC to write data to TDR
[Clearing conditions] * * 1 MPB 0 R
Multiprocessor Bit Stores the multiprocessor bit value in the receive frame. When the RE bit in SCR is cleared to 0 its previous state is retained.
0
MPBT
0
R/W
Multiprocessor Bit Transfer Sets the multiprocessor bit value to be added to the transmit frame.
Note:
*
Only 0 can be written, to clear the flag.
Bit Functions in Smart Card Interface Mode (When SMIF in SCMR = 1):
Bit 7 Bit Name TDRE Initial Value 1 R/W Description
R/(W)* Transmit Data Register Empty Indicates whether TDR contains transmit data. [Setting conditions] * * * When the TE bit in SCR is 0 When data is transferred from TDR to TSR When 0 is written to TDRE after reading TDRE = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.) When a TXI interrupt request is issued allowing DTC to write data to TDR
[Clearing conditions]
*
Rev.2.00 Jun. 28, 2007 Page 466 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Bit 6
Bit Name RDRF
Initial Value 0
R/W
Description
R/(W)* Receive Data Register Full Indicates whether receive data is stored in RDR. [Setting condition] * When serial reception ends normally and receive data is transferred from RSR to RDR When 0 is written to RDRF after reading RDRF = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.) When an RXI interrupt request is issued allowing DTC to read data from RDR
[Clearing conditions] *
*
The RDRF flag is not affected and retains its previous value even when the RE bit in SCR is cleared to 0. Note that when the next reception is completed while the RDRF flag is being set to 1, an overrun error occurs and the received data is lost. 5 ORER 0 R/(W)* Overrun Error Indicates that an overrun error has occurred during reception and the reception ends abnormally. [Setting condition] * When the next serial reception is completed while RDRF = 1 In RDR, the receive data prior to an overrun error occurrence is retained, but data received following the overrun error occurrence is lost. When the ORER flag is set to 1, subsequent serial reception cannot be performed. Note that, in clocked synchronous mode, serial transmission also cannot continue. [Clearing condition] * When 0 is written to ORER after reading ORER = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.) Even when the RE bit in SCR is cleared, the ORER flag is not affected and retains its previous value.
Rev.2.00 Jun. 28, 2007 Page 467 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Bit 4
Bit Name ERS
Initial Value 0
R/W
Description [Setting condition] * * When a low error signal is sampled When 0 is written to ERS after reading ERS = 1 [Clearing condition]
R/(W)* Error Signal Status
3
PER
0
R/(W)* Parity Error Indicates that a parity error has occurred during reception in asynchronous mode and the reception ends abnormally. [Setting condition] * When a parity error is detected during reception Receive data when the parity error occurs is transferred to RDR, however, the RDRF flag is not set. Note that when the PER flag is being set to 1, the subsequent serial reception cannot be performed. In clocked synchronous mode, serial transmission also cannot continue. [Clearing condition] * When 0 is written to PER after reading PER = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.) Even when the RE bit in SCR is cleared, the PER flag is not affected and retains its previous value.
Rev.2.00 Jun. 28, 2007 Page 468 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Bit 2
Bit Name TEND
Initial Value 1
R/W R
Description Transmit End This bit is set to 1 when no error signal is sent from the receiving side and the next transmit data is ready to be transferred to TDR. [Setting conditions] * * When both the TE and ERS bits in SCR are 0 When ERS = 0 and TDRE = 1 after a specified time passed after completion of 1-byte data transfer. The set timing depends on the register setting as follows: When GM = 0 and BLK = 0, 2.5 etu after transmission start When GM = 0 and BLK = 1, 1.5 etu after transmission start When GM = 1 and BLK = 0, 1.0 etu after transmission start When GM = 1 and BLK = 1, 1.0 etu after transmission start [Clearing conditions] * * When 0 is written to TEND after reading TEND = 1 When a TXI interrupt request is issued allowing DTC to write the next data to TDR
1 0 Note: *
MPB MPBT
0 0
R R/W
Multiprocessor Bit Not used in smart card interface mode. Multiprocessor Bit Transfer Write 0 to this bit in smart card interface mode.
Only 0 can be written, to clear the flag.
Rev.2.00 Jun. 28, 2007 Page 469 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.3.8
Smart Card Mode Register (SCMR)
SCMR selects smart card interface mode and its format.
Bit Bit Name Initial Value R/W 7 1 R 6 1 R 5 1 R 4 1 R 3 SDIR 0 R/W 2 SINV 0 R/W 1 1 R 0 SMIF 0 R/W
Bit 7 to 4 3
Bit Name SDIR
Initial Value All 1 0
R/W R R/W
Description Reserved These are read-only bits and cannot be modified. Smart Card Data Transfer Direction Selects the serial/parallel conversion format. 0: Transfer with LSB-first 1: Transfer with MSB-first This bit is valid only when the 8-bit data format is used for transmission/reception; when the 7-bit data format is used, data is always transmitted/received with LSB-first.
2
SINV
0
R/W
Smart Card Data Invert Inverts the transmit/receive data logic level. This bit does not affect the logic level of the parity bit. To invert the parity bit, invert the O/E bit in SMR. 0: TDR contents are transmitted as they are. Receive data is stored as it is in RDR. 1: TDR contents are inverted before being transmitted. Receive data is stored in inverted form in RDR.
1 0
SMIF
1 0
R R/W
Reserved This is a read-only bit and cannot be modified. Smart Card Interface Mode Select When this bit is set to 1, smart card interface mode is selected. 0: Normal asynchronous or clocked synchronous mode 1: Smart card interface mode
Rev.2.00 Jun. 28, 2007 Page 470 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.3.9
Bit Rate Register (BRR)
BRR is an 8-bit register that adjusts the bit rate. As the SCI performs baud rate generator control independently for each channel, different bit rates can be set for each channel. Table 13.2 shows the relationships between the N setting in BRR and bit rate B for normal asynchronous mode and clocked synchronous mode, and smart card interface mode. The initial value of BRR is H'FF, and it can be read from or written to by the CPU at all times. Table 13.2 Relationships between N Setting in BRR and Bit Rate B
Mode Asynchronous mode Clocked synchronous mode Smart card interface mode Bit Rate
N= P x 10 64 x 2 N=
6 2n - 1
Error
-1 xB -1
P x 106 Error (%) = { BxSx2
2n + 1
Error (%) = {
P x 106 B x 64 x 2
2n - 1
- 1 } x 100 x (N + 1)
P x 106 8x2
2n - 1
xB -1
- 1 } x 100 x (N + 1)
N=
P x 106 Sx2
2n + 1
xB
[Legend] B: Bit rate (bit/s) N: BRR setting for baud rate generator (0 N 255) P: Operating frequency (MHz) n and S: Determined by the SMR settings shown in the following table. SMR Setting CKS1 0 0 1 1 CKS0 0 1 0 1 n 0 1 2 3 BCP1 0 0 1 1 SMR Setting BCP0 0 1 0 1 S 32 64 372 256
Table 13.3 shows sample N settings in BRR in normal asynchronous mode. Table 13.4 shows the maximum bit rate settable for each operating frequency. Tables 13.6 and 13.8 show sample N settings in BRR in clocked synchronous mode and smart card interface mode, respectively. In smart card interface mode, the number of basic clock cycles S in a 1-bit data transfer time can be selected. For details, see section 13.7.4, Receive Data Sampling Timing and Reception Margin. Tables 13.5 and 13.7 show the maximum bit rates with external clock input.
Rev.2.00 Jun. 28, 2007 Page 471 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Table 13.3 Examples of BRR Settings for Various Bit Rates (Asynchronous Mode) (1)
Operating Frequency P (MHz) 8 Bit Rate (bit/s) n 110 150 300 600 1200 2400 4800 9600 19200 31250 38400 2 2 1 1 0 0 0 0 0 0 N 141 103 207 103 207 103 51 25 12 7 Error (%) 0.03 0.16 0.16 0.16 0.16 0.16 0.16 0.16 0.16 0.00 n 2 2 1 1 0 0 0 0 0 0 0 9.8304 N 174 127 255 127 255 127 63 31 15 9 7 Error (%) -0.26 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 -1.70 0.00 n 2 2 2 1 1 0 0 0 0 0 0 N 177 129 64 129 64 129 64 32 15 9 7 10 Error (%) -0.25 0.16 0.16 0.16 0.16 0.16 0.16 -1.36 1.73 0.00 1.73 n 2 2 2 1 1 0 0 0 0 0 0 N 212 155 77 155 77 155 77 38 19 11 9 12 Error (%) 0.03 0.16 0.16 0.16 0.16 0.16 0.16 0.16 -2.34 0.00 -2.34
Operating Frequency P (MHz) 12.288 Bit Rate (bit/s) n 110 150 300 600 1200 2400 4800 9600 19200 31250 38400 2 2 2 1 1 0 0 0 0 0 0 N 217 159 79 159 79 159 79 39 19 11 9 Error (%) 0.08 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 2.40 0.00 n 2 2 2 1 1 0 0 0 0 0 N 248 181 90 181 90 181 90 45 22 13 14 Error (%) -0.17 0.16 0.16 0.16 0.16 0.16 0.16 -0.93 -0.93 0.00 n 3 2 2 1 1 0 0 0 0 0 0 14.7456 N 64 191 95 191 95 191 95 47 23 14 11 Error (%) 0.70 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 -1.70 0.00 n 3 2 2 1 1 0 0 0 0 0 0 N 70 207 103 207 103 207 103 51 25 15 12 16 Error (%) 0.03 0.16 0.16 0.16 0.16 0.16 0.16 0.16 0.16 0.00 0.16
Rev.2.00 Jun. 28, 2007 Page 472 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Table 13.3 Examples of BRR Settings for Various Bit Rates (Asynchronous Mode) (2)
Operating Frequency P (MHz) 17.2032 Bit Rate (bit/s) n 110 150 300 600 1200 2400 4800 9600 19200 31250 38400 3 2 2 1 1 0 0 0 0 0 0 N 75 223 111 223 111 223 111 55 27 16 13 Error (%) 0.48 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 1.20 0.00 n 3 2 2 1 1 0 0 0 0 0 0 N 79 233 116 233 116 233 116 58 28 17 14 18 Error (%) -0.12 0.16 0.16 0.16 0.16 0.16 0.16 -0.69 1.02 0.00 -2.34 n 3 2 2 1 1 0 0 0 0 0 0 19.6608 N 86 255 127 255 127 255 127 63 31 19 15 Error (%) 0.31 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 -1.70 0.00 n 3 3 2 2 1 1 0 0 0 0 0 N 88 64 129 64 129 64 129 64 32 19 15 20 Error (%) -0.25 0.16 0.16 0.16 0.16 0.16 0.16 0.16 -1.36 0.00 1.73
Operating Frequency P (MHz) 25 Bit Rate (bit/s) n 110 150 300 600 1200 2400 4800 9600 19200 31250 38400 3 3 2 2 1 1 0 0 0 0 0 N 110 80 162 80 162 80 162 80 40 24 19 Error (%) -0.02 -0.47 0.15 -0.47 0.15 -0.47 0.15 -0.47 -0.76 0.00 1.73 n 3 3 2 2 1 1 0 0 0 0 0 N 132 97 194 97 194 97 194 97 48 29 23 30 Error (%) 0.13 -0.35 0.16 -0.35 0.16 -0.35 0.16 -0.35 -0.35 0 1.73 n 3 3 2 2 1 1 0 0 0 0 0 N 145 106 214 106 214 106 214 106 53 32 26 33 Error (%) 0.33 0.39 -0.07 0.39 -0.07 0.39 -0.07 0.39 -0.54 0 -0.54 n 3 3 2 2 1 1 0 0 0 0 0 N 154 113 227 113 227 113 227 113 56 34 28 35 Error (%) 0.23 -0.06 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 -1.78
Rev.2.00 Jun. 28, 2007 Page 473 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Table 13.4 Maximum Bit Rate for Each Operating Frequency (Asynchronous Mode)
P (MHz) 8 9.8304 10 12 12.288 14 14.7456 16 17.2032 18 19.6608 20 25 30 33 35 Maximum Bit Rate (bit/s) 250000 307200 312500 375000 384000 437500 460800 500000 537600 562500 614400 625000 781250 937500 1031250 1093750 n 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 N 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
Rev.2.00 Jun. 28, 2007 Page 474 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Table 13.5 Maximum Bit Rate with External Clock Input (Asynchronous Mode)
P (MHz) 8 9.8304 10 12 12.288 14 14.7456 16 17.2032 18 19.6608 20 25 30 33 35 External Input Clock (MHz) 2.0000 2.4576 2.5000 3.0000 3.0720 3.5000 3.6864 4.0000 4.3008 4.5000 4.9152 5.0000 6.2500 7.5000 8.2500 8.7500 Maximum Bit Rate (bit/s) 125000 153600 156250 187500 192000 218750 230400 250000 268800 281250 307200 312500 390625 468750 515625 546875
Rev.2.00 Jun. 28, 2007 Page 475 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Table 13.6 BRR Settings for Various Bit Rates (Clocked Synchronous Mode)
Operating Frequency P (MHz) Bit Rate (bit/s) 110 250 500 1k 2.5k 5k 10k 25k 50k 100k 250k 500k 1M 2.5M 5M 3 2 2 1 1 0 0 0 0 0 0 0 124 249 124 199 99 199 79 39 19 7 3 1 0 0* 1 1 0 0 0 0 0 0 249 124 249 99 49 24 9 4 3 3 2 2 1 1 0 0 0 0 0 0 249 124 249 99 199 99 159 79 39 15 7 3 2 1 1 0 0 0 0 0 0 0 0 124 249 124 199 99 49 19 9 4 1 0* 8 n N n 10 N n 16 N n 20 N
Rev.2.00 Jun. 28, 2007 Page 476 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Operating Frequency P (MHz) Bit Rate (bit/s) 110 250 500 1k 2.5k 5k 10k 25k 50k 100k 250k 500k 1M 2.5M 5M 3 2 2 1 0 0 0 0 97 155 77 155 249 124 62 24 3 3 2 2 1 1 0 0 0 0 0 233 116 187 93 187 74 149 74 29 14 2 3 2 2 1 1 0 0 0 128 205 102 205 82 164 82 32 3 2 2 1 1 0 0 0 136 218 108 218 87 174 87 34 25 n N n 30 N n 33 N n 35 N
[Legend] Space: Setting prohibited. : Can be set, but there will be error. *: Continuous transmission or reception is not possible.
Table 13.7 Maximum Bit Rate with External Clock Input (Clocked Synchronous Mode)
P (MHz) 8 10 12 14 16 18 External Input Clock (MHz) 1.3333 1.6667 2.0000 2.3333 2.6667 3.0000 Maximum Bit Rate (bit/s) 1333333.3 1666666.7 2000000.0 2333333.3 2666666.7 3000000.0 P (MHz) 20 25 30 33 35 External Input Clock (MHz) 3.3333 4.1667 5.0000 5.5000 5.8336 Maximum Bit Rate (bit/s) 3333333.3 4166666.7 5000000.0 5500000.0 5833625.0
Rev.2.00 Jun. 28, 2007 Page 477 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Table 13.8 BRR Settings for Various Bit Rates (Smart Card Interface Mode, n = 0, S = 372)
Operating Frequency P (MHz) Bit Rate (bit/s) 9600 n 0 N 0 7.1424 Error (%) n 0.00 0 N 1 10.00 Error (%) n 30 0 10.7136 N 1 Error (%) n 25 0 N 1 13.00 Error (%) 8.99
Operating Frequency P (MHz) Bit Rate (bit/s) 9600 n 0 14.2848 N 1 Error (%) n 0.00 0 N 1 16.00 Error (%) n 12.01 0 N 2 18.00 Error (%) n 15.99 0 N 2 20.00 Error (%) 6.60
Operating Frequency P (MHz) Bit Rate (bit/s) 9600 n 0 N 3 25.00 Error (%) n 12.49 0 N 3 30.00 Error (%) n 5.01 0 N 4 33.00 Error (%) n 7.59 0 N 4 35.00 Error (%) 1.99
Table 13.9 Maximum Bit Rate for Each Operating Frequency (Smart Card Interface Mode, S = 372)
P (MHz) 7.1424 10.00 10.7136 13.00 14.2848 16.00 Maximum Bit Rate (bit/s) 9600 13441 14400 17473 19200 21505 n 0 0 0 0 0 0 N 0 0 0 0 0 0 P (MHz) 18.00 20.00 25.00 30.00 33.00 35.00 Maximum Bit Rate (bit/s) 24194 26882 33602 40323 44355 47043 n 0 0 0 0 0 0 N 0 0 0 0 0 0
Rev.2.00 Jun. 28, 2007 Page 478 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.3.10 Serial Extended Mode Register (SEMR) SEMR selects the clock source in asynchronous mode. The basic clock is automatically specified when the average transfer rate operation is selected.
Bit Bit Name Initial Value R/W 7 0 R/W 6 0 R 5 0 R 4 0 R 3 ABCS 0 R/W 2 ACS2 0 R/W 1 ACS1 0 R/W 0 ACS0 0 R/W
Bit 7
Bit Name
Initial Value 0
R/W R/W
Description Reserved This bit is always read as 0. The write value should always be 0.
6 to 4 3
ABCS
All 0 0
R R/W
Reserved These are read-only bits and cannot be modified. Asynchronous Mode Basic Clock Select (valid only in asynchronous mode) Selects the basic clock for a 1-bit period. 0: The basic clock has a frequency 16 times the transfer rate 1: The basic clock has a frequency 8 times the transfer rate
Rev.2.00 Jun. 28, 2007 Page 479 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Bit 2 1 0
Bit Name ACS2 ACS1 ACS0
Initial Value 0 0 0
R/W R/W R/W R/W
Description Asynchronous Mode Clock Source Select (valid when CKE1 = 1 in asynchronous mode) These bits select the clock source for the average transfer rate function. When the average transfer rate function is enabled, the basic clock is automatically specified regardless of the ABCS bit value. 000: External clock input 001: 115.152 kbps of average transfer rate specific to P = 10.667 MHz is selected (operated using the basic clock with a frequency 16 times the transfer rate) 010: 460.606 kbps of average transfer rate specific to P = 10.667 MHz is selected (operated using the basic clock with a frequency 8 times the transfer rate) 011: 720 kbps of average transfer rate specific to P = 32 MHz is selected (operated using the basic clock with a frequency 16 times the transfer rate) 100: Setting prohibited 101: 115.196 kbps of average transfer rate specific to P = 16 MHz is selected (operated using the basic clock with a frequency 16 times the transfer rate) 110: 460.784 kbps of average transfer rate specific to P = 16 MHz is selected (operated using the basic clock with a frequency 16 times the transfer rate) 111: 720 kbps of average transfer rate specific to P = 16 MHz is selected (operated using the basic clock with a frequency 8 times the transfer rate) The average transfer rate only supports operating frequencies of 10.667 MHz, 16 MHz, and 32 MHz.
Rev.2.00 Jun. 28, 2007 Page 480 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.4
Operation in Asynchronous Mode
Figure 13.2 shows the general format for asynchronous serial communication. One frame consists of a start bit (low level), followed by transmit/receive data, a parity bit, and finally stop bits (high level). In asynchronous serial communication, the communication line is usually held in the mark state (high level). The SCI monitors the communication line, and when it goes to the space state (low level), recognizes a start bit and starts serial communication. Inside the SCI, the transmitter and receiver are independent units, enabling full-duplex communication. Both the transmitter and the receiver also have a double-buffered structure, so that data can be read or written during transmission or reception, enabling continuous data transmission and reception.
Idle state (mark state) 1 Serial data 0 Start bit 1 bit LSB D0 D1 D2 D3 D4 D5 D6 MSB D7 0/1 1 1 1
Transmit/receive data 7 or 8 bits
Parity Stop bit bit 1 bit or 1 or 2 none bits
One unit of transfer data (character or frame)
Figure 13.2 Data Format in Asynchronous Communication (Example with 8-Bit Data, Parity, Two Stop Bits)
Rev.2.00 Jun. 28, 2007 Page 481 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.4.1
Data Transfer Format
Table 13.10 shows the data transfer formats that can be used in asynchronous mode. Any of 12 transfer formats can be selected according to the SMR setting. For details on the multiprocessor bit, see section 13.5, Multiprocessor Communication Function. Table 13.10 Serial Transfer Formats (Asynchronous Mode)
SMR Settings CHR 0 PE 0 MP 0 STOP 0 1 S Serial Transmit/Receive Format and Frame Length 2 3 4 5 6 7 8 9 10
STOP
11
12
8-bit data
0
0
0
1
S
8-bit data
STOP STOP
0
1
0
0
S
8-bit data
P
STOP
0
1
0
1
S
8-bit data
P
STOP STOP
1
0
0
0
S
7-bit data
STOP
1
0
0
1
S
7-bit data
STOP STOP
1
1
0
0
S
7-bit data
P
STOP
1
1
0
1
S
7-bit data
P
STOP STOP
0
--
1
0
S
8-bit data
MPB STOP
0
--
1
1
S
8-bit data
MPB STOP STOP
1
--
1
0
S
7-bit data
MPB STOP
1
--
1
1
S
7-bit data
MPB STOP STOP
[Legend] S: Start bit STOP: Stop bit P: Parity bit MPB: Multiprocessor bit
Rev.2.00 Jun. 28, 2007 Page 482 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.4.2
Receive Data Sampling Timing and Reception Margin in Asynchronous Mode
In asynchronous mode, the SCI operates on a basic clock with a frequency of 16 times the bit rate. In reception, the SCI samples the falling edge of the start bit using the basic clock, and performs internal synchronization. Since receive data is sampled at the rising edge of the 8th pulse of the basic clock, data is latched at the middle of each bit, as shown in figure 13.3. Thus the reception margin in asynchronous mode is determined by formula (1) below.
M = | (0.5 - 1 ) - (L - 0.5) F - | D - 0.5 | (1 + F ) | x 100 2N N [%] ... Formula (1)
M: Reception margin N: Ratio of bit rate to clock (N = 16) D: Duty cycle of clock (D = 0.5 to 1.0) L: Frame length (L = 9 to 12) F: Absolute value of clock frequency deviation
Assuming values of F = 0 and D = 0.5 in formula (1), the reception margin is determined by the formula below.
M = ( 0.5 - 1 ) x 100[%] = 46.875% 2 x 16
However, this is only the computed value, and a margin of 20% to 30% should be allowed in system design.
16 clocks 8 clocks 0 Internal basic clock Receive data (RxD) Synchronization sampling timing Data sampling timing Start bit D0 D1 7 15 0 7 15 0
Figure 13.3 Receive Data Sampling Timing in Asynchronous Mode
Rev.2.00 Jun. 28, 2007 Page 483 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.4.3
Clock
Either an internal clock generated by the on-chip baud rate generator or an external clock input to the SCK pin can be selected as the SCI's transfer clock, according to the setting of the C/A bit in SMR and the CKE1 and CKE0 bits in SCR. When an external clock is input to the SCK pin, the clock frequency should be 16 times the bit rate used. When the SCI is operated on an internal clock, the clock can be output from the SCK pin. The frequency of the clock output in this case is equal to the bit rate, and the phase is such that the rising edge of the clock is in the middle of the transmit data, as shown in figure 13.4.
SCK TxD 0 D0 D1 D2 D3 D4 D5 D6 D7 0/1 1 1
1 frame
Figure 13.4 Phase Relation between Output Clock and Transmit Data (Asynchronous Mode)
Rev.2.00 Jun. 28, 2007 Page 484 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.4.4
SCI Initialization (Asynchronous Mode)
Before transmitting and receiving data, first clear the TE and RE bits in SCR to 0, then initialize the SCI as described in a sample flowchart in figure 13.5. When the operating mode, transfer format, etc., is changed, the TE and RE bits must be cleared to 0 before making the change. When the TE bit is cleared to 0, the TDRE flag is set to 1. Note that clearing the RE bit to 0 does not initialize the RDRF, PER, FER, and ORER flags, or RDR. When the external clock is used in asynchronous mode, the clock must be supplied even during initialization.
Start initialization [1] Clear TE and RE bits in SCR to 0 Set corresponding bit in ICR to 1 [1] [2] Set the bit in ICR for the corresponding pin when receiving data or using an external clock. Set the clock selection in SCR. Be sure to clear bits RIE, TIE, TEIE, and MPIE, and bits TE and RE, to 0. When the clock output is selected in asynchronous mode, the clock is output immediately after SCR settings are made. [3] [4] Set the data transfer format in SMR and SCMR. Write a value corresponding to the bit rate to BRR. This step is not necessary if an external clock is used. Wait at least one bit interval, then set the TE bit or RE bit in SCR to 1. Also set the RIE, TIE, TEIE, and MPIE bits. Setting the TE and RE bits enables the TxD and RxD pins to be used.
Set CKE1 and CKE0 bits in SCR (TE and RE bits are 0) Set data transfer format in SMR and SCMR Set value in BRR Wait
[2]
[3]
[4]
No 1-bit interval elapsed Yes Set TE or RE bit in SCR to 1, and set RIE, TIE, TEIE, and MPIE bits [5]
[5]

Figure 13.5 Sample SCI Initialization Flowchart
Rev.2.00 Jun. 28, 2007 Page 485 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.4.5
Serial Data Transmission (Asynchronous Mode)
Figure 13.6 shows an example of the operation for transmission in asynchronous mode. In transmission, the SCI operates as described below. 1. The SCI monitors the TDRE flag in SSR, and if it is cleared to 0, recognizes that data has been written to TDR, and transfers the data from TDR to TSR. 2. After transferring data from TDR to TSR, the SCI sets the TDRE flag to 1 and starts transmission. If the TIE bit in SCR is set to 1 at this time, a TXI interrupt request is generated. Because the TXI interrupt processing routine writes the next transmit data to TDR before transmission of the current transmit data has finished, continuous transmission can be enabled. 3. Data is sent from the TxD pin in the following order: start bit, transmit data, parity bit or multiprocessor bit (may be omitted depending on the format), and stop bit. 4. The SCI checks the TDRE flag at the timing for sending the stop bit. 5. If the TDRE flag is 0, the next transmit data is transferred from TDR to TSR, the stop bit is sent, and then serial transmission of the next frame is started. 6. If the TDRE flag is 1, the TEND flag in SSR is set to 1, the stop bit is sent, and then the mark state is entered in which 1 is output. If the TEIE bit in SCR is set to 1 at this time, a TEI interrupt request is generated. Figure 13.7 shows a sample flowchart for transmission in asynchronous mode.
Start bit Data Parity Stop Start bit bit bit Data Parity Stop bit bit
1
1
Idle state (mark state)
0
D0
D1
D7
0/1
1
0
D0
D1
D7
0/1
1
TDRE TEND
TXI interrupt request generated Data written to TDR and TDRE flag cleared to 0 in TXI interrupt processing routine TXI interrupt request generated
TEI interrupt request generated
1 frame
Figure 13.6 Example of Operation for Transmission in Asynchronous Mode (Example with 8-Bit Data, Parity, One Stop Bit)
Rev.2.00 Jun. 28, 2007 Page 486 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Initialization Start transmission
[1]
Read TDRE flag in SSR No
[2]
[1] SCI initialization: The TxD pin is automatically designated as the transmit data output pin. After the TE bit is set to 1, a 1 is output for a frame, and transmission is enabled. [2] SCI state check and transmit data write: Read SSR and check that the TDRE flag is set to 1, then write transmit data to TDR and clear the TDRE flag to 0. [3] Serial transmission continuation procedure: To continue serial transmission, read 1 from the TDRE flag to confirm that writing is possible, then write data to TDR, and clear the TDRE flag to 0. However, the TDRE flag is checked and cleared automatically when the DTC is initiated by a transmit data empty interrupt (TXI) request and writes data to TDR. [4] Break output at the end of serial transmission: To output a break in serial transmission, set DDR for the port corresponding to the TxD pin to 1, clear DR to 0, then clear the TE bit in SCR to 0.
TDRE = 1 Yes Write transmit data to TDR and clear TDRE flag in SSR to 0
All data transmitted? Yes
No
[3] Read TEND flag in SSR No
TEND = 1 Yes Break output Yes Clear DR to 0 and set DDR to 1
No
[4]
Clear TE bit in SCR to 0
Figure 13.7 Sample Serial Transmission Flowchart
Rev.2.00 Jun. 28, 2007 Page 487 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.4.6
Serial Data Reception (Asynchronous Mode)
Figure 13.8 shows an example of the operation for reception in asynchronous mode. In serial reception, the SCI operates as described below. 1. The SCI monitors the communication line, and if a start bit is detected, performs internal synchronization, stores receive data in RSR, and checks the parity bit and stop bit. 2. If an overrun error (when reception of the next data is completed while the RDRF flag in SSR is still set to 1) occurs, the ORER bit in SSR is set to 1. If the RIE bit in SCR is set to 1 at this time, an ERI interrupt request is generated. Receive data is not transferred to RDR. The RDRF flag remains to be set to 1. 3. If a parity error is detected, the PER bit in SSR is set to 1 and receive data is transferred to RDR. If the RIE bit in SCR is set to 1 at this time, an ERI interrupt request is generated. 4. If a framing error (when the stop bit is 0) is detected, the FER bit in SSR is set to 1 and receive data is transferred to RDR. If the RIE bit in SCR is set to 1 at this time, an ERI interrupt request is generated. 5. If reception finishes successfully, the RDRF bit in SSR is set to 1, and receive data is transferred to RDR. If the RIE bit in SCR is set to 1 at this time, an RXI interrupt request is generated. Because the RXI interrupt processing routine reads the receive data transferred to RDR before reception of the next receive data has finished, continuous reception can be enabled.
Start bit Data Parity Stop Start bit bit bit Data Parity Stop bit bit
1
1
Idle state (mark state)
0
D0
D1
D7
0/1
1
0
D0
D1
D7
0/1
0
RDRF FER
RXI interrupt request generated RDR data read and RDRF flag cleared to 0 in RXI interrupt processing routine
1 frame
ERI interrupt request generated by framing error
Figure 13.8 Example of SCI Operation for Reception (Example with 8-Bit Data, Parity, One Stop Bit)
Rev.2.00 Jun. 28, 2007 Page 488 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Table 13.11 shows the states of the SSR status flags and receive data handling when a receive error is detected. If a receive error is detected, the RDRF flag retains its state before receiving data. Reception cannot be resumed while a receive error flag is set to 1. Accordingly, clear the ORER, FER, PER, and RDRF bits to 0 before resuming reception. Figure 13.9 shows a sample flowchart for serial data reception. Table 13.11 SSR Status Flags and Receive Data Handling
SSR Status Flag RDRF* 1 0 0 1 1 0 1 Note: * ORER 1 0 0 1 1 0 1 FER 0 1 0 1 0 1 1 PER 0 0 1 0 1 1 1 Receive Data Lost Transferred to RDR Transferred to RDR Lost Lost Transferred to RDR Lost Receive Error Type Overrun error Framing error Parity error Overrun error + framing error Overrun error + parity error Framing error + parity error Overrun error + framing error + parity error
The RDRF flag retains the state it had before data reception.
Rev.2.00 Jun. 28, 2007 Page 489 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Initialization Start reception
[1]
[1] SCI initialization: The RxD pin is automatically designated as the receive data input pin.
[2] [3] Receive error processing and break detection: [2] If a receive error occurs, read the ORER, PER, and FER flags in SSR to identify the error. After performing the appropriate error processing, ensure Yes PER FER ORER = 1 that the ORER, PER, and FER flags are [3] all cleared to 0. Reception cannot be No resumed if any of these flags are set to Error processing 1. In the case of a framing error, a (Continued on next page) break can be detected by reading the value of the input port corresponding to [4] Read RDRF flag in SSR the RxD pin. Read ORER, PER, and FER flags in SSR No [4] SCI state check and receive data read: Read SSR and check that RDRF = 1, then read the receive data in RDR and clear the RDRF flag to 0. Transition of the RDRF flag from 0 to 1 can also be identified by an RXI interrupt. [5] Serial reception continuation procedure: To continue serial reception, before the stop bit for the current frame is received, read the RDRF flag and RDR, and clear the RDRF flag to 0. However, the RDRF flag is cleared automatically when the DTC is initiated by an RXI interrupt and reads data from RDR.
RDRF = 1 Yes Read receive data in RDR, and clear RDRF flag in SSR to 0
No
All data received? Yes Clear RE bit in SCR to 0
[5]
Figure 13.9 Sample Serial Reception Flowchart (1)
Rev.2.00 Jun. 28, 2007 Page 490 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
[3] Error processing
No
ORER = 1 Yes Overrun error processing
No
FER = 1 Yes Break? No Framing error processing Clear RE bit in SCR to 0 Yes
No
PER = 1 Yes Parity error processing
Clear ORER, PER, and FER flags in SSR to 0

Figure 13.9 Sample Serial Reception Flowchart (2)
Rev.2.00 Jun. 28, 2007 Page 491 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.5
Multiprocessor Communication Function
Use of the multiprocessor communication function enables data transfer to be performed among a number of processors sharing communication lines by means of asynchronous serial communication using the multiprocessor format, in which a multiprocessor bit is added to the transfer data. When multiprocessor communication is carried out, each receiving station is addressed by a unique ID code. The serial communication cycle consists of two component cycles: an ID transmission cycle which specifies the receiving station, and a data transmission cycle for the specified receiving station. The multiprocessor bit is used to differentiate between the ID transmission cycle and the data transmission cycle. If the multiprocessor bit is 1, the cycle is an ID transmission cycle, and if the multiprocessor bit is 0, the cycle is a data transmission cycle. Figure 13.10 shows an example of inter-processor communication using the multiprocessor format. The transmitting station first sends data which includes the ID code of the receiving station and a multiprocessor bit set to 1. It then transmits transmit data added with a multiprocessor bit cleared to 0. The receiving station skips data until data with a 1 multiprocessor bit is sent. When data with a 1 multiprocessor bit is received, the receiving station compares that data with its own ID. The station whose ID matches then receives the data sent next. Stations whose ID does not match continue to skip data until data with a 1 multiprocessor bit is again received. The SCI uses the MPIE bit in SCR to implement this function. When the MPIE bit is set to 1, transfer of receive data from RSR to RDR, error flag detection, and setting the SSR status flags, RDRF, FER, and ORER in SSR to 1 are prohibited until data with a 1 multiprocessor bit is received. On reception of a receive character with a 1 multiprocessor bit, the MPB bit in SSR is set to 1 and the MPIE bit is automatically cleared, thus normal reception is resumed. If the RIE bit in SCR is set to 1 at this time, an RXI interrupt is generated. When the multiprocessor format is selected, the parity bit setting is invalid. All other bit settings are the same as those in normal asynchronous mode. The clock used for multiprocessor communication is the same as that in normal asynchronous mode.
Rev.2.00 Jun. 28, 2007 Page 492 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Transmitting station Communication line
Receiving station A (ID = 01) Serial data
Receiving station B (ID = 02)
Receiving station C (ID = 03)
Receiving station D (ID = 04)
H'01 (MPB = 1)
H'AA (MPB = 0)
ID transmission cycle = receiving station specification [Legend] MPB: Multiprocessor bit
Data transmission cycle = Data transmission to receiving station specified by ID
Figure 13.10 Example of Communication Using Multiprocessor Format (Transmission of Data H'AA to Receiving Station A)
Rev.2.00 Jun. 28, 2007 Page 493 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.5.1
Multiprocessor Serial Data Transmission
Figure 13.11 shows a sample flowchart for multiprocessor serial data transmission. For an ID transmission cycle, set the MPBT bit in SSR to 1 before transmission. For a data transmission cycle, clear the MPBT bit in SSR to 0 before transmission. All other SCI operations are the same as those in asynchronous mode.
Initialization Start transmission Read TDRE flag in SSR No
[1]
[2]
[1] SCI initialization: The TxD pin is automatically designated as the transmit data output pin. After the TE bit is set to 1, a 1 is output for one frame, and transmission is enabled. [2] SCI status check and transmit data write: Read SSR and check that the TDRE flag is set to 1, then write transmit data to TDR. Set the MPBT bit in SSR to 0 or 1. Finally, clear the TDRE flag to 0. [3] Serial transmission continuation procedure: To continue serial transmission, be sure to read 1 from the TDRE flag to confirm that writing is possible, then write data to TDR, and then clear the TDRE flag to 0. However, the TDRE flag is checked and cleared automatically when the DTC is initiated by a transmit data empty interrupt (TXI) request and writes data to TDR. [4] Break output at the end of serial transmission: To output a break in serial transmission, set DDR for the port to 1, clear DR to 0, and then clear the TE bit in SCR to 0.
TDRE = 1 Yes Write transmit data to TDR and set MPBT bit in SSR Clear TDRE flag to 0
All data transmitted? Yes Read TEND flag in SSR
No
[3]
TEND = 1 Yes Break output? Yes Clear DR to 0 and set DDR to 1
No
No
[4]
Clear TE bit in SCR to 0

Figure 13.11 Sample Multiprocessor Serial Transmission Flowchart
Rev.2.00 Jun. 28, 2007 Page 494 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.5.2
Multiprocessor Serial Data Reception
Figure 13.13 shows a sample flowchart for multiprocessor serial data reception. If the MPIE bit in SCR is set to 1, data is skipped until data with a 1 multiprocessor bit is sent. On receiving data with a 1 multiprocessor bit, the receive data is transferred to RDR. An RXI interrupt request is generated at this time. All other SCI operations are the same as in asynchronous mode. Figure 13.12 shows an example of SCI operation for multiprocessor format reception.
Start bit Data (ID1) MPB Stop bit Start bit Data (Data 1) Stop MPB bit
1
1
(mark state)
0
D0
D1
D7
1
1
0
D0
D1
D7
0
1 Idle state
MPIE RDRF RDR value
MPIE = 0 RXI interrupt request (multiprocessor interrupt) generated RDR data read and RDRF flag cleared to 0 in RXI interrupt processing routine
ID1
If not this station's ID, MPIE bit is set to 1 again RXI interrupt request is not generated, and RDR retains its state
(a) Data does not match station's ID
Start bit Data (ID2) Stop MPB bit Start bit Data (Data 2) Stop MPB bit
1
1
(mark state)
0
D0
D1
D7
1
1
0
D0
D1
D7
0
1 Idle state
MPIE RDRF RDR value
ID1
MPIE = 0 RXI interrupt request (multiprocessor interrupt) generated RDR data read and RDRF flag cleared to 0 in RXI interrupt processing routine
ID2
Data 2
Matches this station's ID, MPIE bit set to 1 so reception continues, and again data is received in RXI interrupt processing routine
(b) Data matches station's ID
Figure 13.12 Example of SCI Operation for Reception (Example with 8-Bit Data, Multiprocessor Bit, One Stop Bit)
Rev.2.00 Jun. 28, 2007 Page 495 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Initialization Start reception Set MPIE bit in SCR to 1 Read ORER and FER flags in SSR FER ORER = 1 No Read RDRF flag in SSR No
[1]
[1] SCI initialization: The RxD pin is automatically designated as the receive data input pin. [2] ID reception cycle: Set the MPIE bit in SCR to 1. [3] SCI state check, ID reception and comparison: Read SSR and check that the RDRF flag is set to 1, then read the receive data in RDR and compare it with this station's ID. If the data is not this station's ID, set the MPIE bit to 1 again, and clear the RDRF flag to 0. If the data is this station's ID, clear the RDRF flag to 0. [4] SCI state check and data reception: Read SSR and check that the RDRF flag is set to 1, then read the data in RDR. [5] Receive error processing and break detection: If a receive error occurs, read the ORER and FER flags in SSR to identify the error. After performing the appropriate error processing, ensure that the ORER and FER flags are both cleared to 0. Reception cannot be resumed if either of these flags is set to 1. In the case of a framing error, a break can be detected by reading the RxD pin value. [4]
[2]
Yes
[3]
RDRF = 1 Yes Read receive data in RDR
No
This station's ID? Yes Read ORER and FER flags in SSR FER ORER = 1 No Read RDRF flag in SSR No Yes
RDRF = 1 Yes Read receive data in RDR No
All data received? Yes Clear RE bit in SCR to 0
[5] Error processing (Continued on next page)
Figure 13.13 Sample Multiprocessor Serial Reception Flowchart (1)
Rev.2.00 Jun. 28, 2007 Page 496 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
[5]
Error processing
No
ORER = 1 Yes Overrun error processing
No
FER = 1 Yes Break? No Framing error processing Clear RE bit in SCR to 0 Yes
Clear ORER, PER, and FER flags in SSR to 0

Figure 13.13 Sample Multiprocessor Serial Reception Flowchart (2)
Rev.2.00 Jun. 28, 2007 Page 497 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.6
Operation in Clocked Synchronous Mode
Figure 13.14 shows the general format for clocked synchronous communication. In clocked synchronous mode, data is transmitted or received in synchronization with clock pulses. One character in transfer data consists of 8-bit data. In data transmission, the SCI outputs data from one falling edge of the synchronization clock to the next. In data reception, the SCI receives data in synchronization with the rising edge of the synchronization clock. After 8-bit data is output, the transmission line holds the MSB output state. In clocked synchronous mode, no parity bit or multiprocessor bit is added. Inside the SCI, the transmitter and receiver are independent units, enabling full-duplex communication by use of a common clock. Both the transmitter and the receiver also have a double-buffered structure, so that the next transmit data can be written during transmission or the previous receive data can be read during reception, enabling continuous data transfer.
One unit of transfer data (character or frame) * Synchronization clock LSB Serial data Don't care Note: * Holds a high level except during continuous transfer. Bit 0 Bit 1 Bit 2 Bit 3 Bit 4 Bit 5 Bit 6 MSB Bit 7 Don't care *
Figure 13.14 Data Format in Clocked Synchronous Communication (LSB-First) 13.6.1 Clock
Either an internal clock generated by the on-chip baud rate generator or an external synchronization clock input at the SCK pin can be selected, according to the setting of the CKE1 and CKE0 bits in SCR. When the SCI is operated on an internal clock, the synchronization clock is output from the SCK pin. Eight synchronization clock pulses are output in the transfer of one character, and when no transfer is performed the clock is fixed high. Note that in the case of reception only, the synchronization clock is output until an overrun error occurs or until the RE bit is cleared to 0.
Rev.2.00 Jun. 28, 2007 Page 498 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.6.2
SCI Initialization (Clocked Synchronous Mode)
Before transmitting and receiving data, first clear the TE and RE bits in SCR to 0, then initialize the SCI as described in a sample flowchart in figure 13.15. When the operating mode, transfer format, etc., is changed, the TE and RE bits must be cleared to 0 before making the change. When the TE bit is cleared to 0, the TDRE flag is set to 1. However, clearing the RE bit to 0 does not initialize the RDRF, PER, FER, and ORER flags, or RDR.
Start initialization [1] Clear TE and RE bits in SCR to 0 Set corresponding bit in ICR to 1 [1] Set the bit in ICR for the corresponding pin when receiving data or using an external clock.
Set CKE1 and CKE0 bits in SCR (TE and RE bits are 0)
[2] Set the clock selection in SCR. Be sure to clear bits RIE, TIE, TEIE, and MPIE, and bits TE and RE, to 0. [3] Set the data transfer format in SMR and SCMR. [4] Write a value corresponding to the bit rate to BRR. This step is not necessary if an external clock is used. [5] Wait at least one bit interval, then set the TE bit or RE bit in SCR to 1. Also set the RIE, TIE TEIE, and MPIE bits. Setting the TE and RE bits enables the TxD and RxD pins to be used.
[2]
Set data transfer format in SMR and SCMR Set value in BRR Wait
[3]
[4]
1-bit interval elapsed? Yes
No
Set TE or RE bit in SCR to 1, and set RIE, TIE, TEIE, and MPIE bits
[5]
Note: In simultaneous transmit and receive operations, the TE and RE bits should both be cleared to 0 or set to 1 simultaneously.
Figure 13.15 Sample SCI Initialization Flowchart
Rev.2.00 Jun. 28, 2007 Page 499 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.6.3
Serial Data Transmission (Clocked Synchronous Mode)
Figure 13.16 shows an example of the operation for transmission in clocked synchronous mode. In transmission, the SCI operates as described below. 1. The SCI monitors the TDRE flag in SSR, and if it is 0, recognizes that data has been written to TDR, and transfers the data from TDR to TSR. 2. After transferring data from TDR to TSR, the SCI sets the TDRE flag to 1 and starts transmission. If the TIE bit in SCR is set to 1 at this time, a TXI interrupt request is generated. Because the TXI interrupt processing routine writes the next transmit data to TDR before transmission of the current transmit data has finished, continuous transmission can be enabled. 3. 8-bit data is sent from the TxD pin synchronized with the output clock when clock output mode has been specified and synchronized with the input clock when use of an external clock has been specified. 4. The SCI checks the TDRE flag at the timing for sending the last bit. 5. If the TDRE flag is cleared to 0, the next transmit data is transferred from TDR to TSR, and serial transmission of the next frame is started. 6. If the TDRE flag is set to 1, the TEND flag in SSR is set to 1, and the TxD pin retains the output state of the last bit. If the TEIE bit in SCR is set to 1 at this time, a TEI interrupt request is generated. The SCK pin is fixed high. Figure 13.17 shows a sample flowchart for serial data transmission. Even if the TDRE flag is cleared to 0, transmission will not start while a receive error flag (ORER, FER, or PER) is set to 1. Make sure to clear the receive error flags to 0 before starting transmission. Note that clearing the RE bit to 0 does not clear the receive error flags.
Rev.2.00 Jun. 28, 2007 Page 500 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Transfer direction Synchronization clock Serial data TDRE TEND TXI interrupt request generated Data written to TDR and TDRE flag cleared to 0 in TXI interrupt processing routine 1 frame TXI interrupt request generated TEI interrupt request generated Bit 0 Bit 1 Bit 7 Bit 0 Bit 1 Bit 6 Bit 7
Figure 13.16 Example of Operation for Transmission in Clocked Synchronous Mode
[1] SCI initialization: The TxD pin is automatically designated as the transmit data output pin. [2] SCI state check and transmit data write: Read SSR and check that the TDRE flag is set to 1, then write transmit data to TDR and clear the TDRE flag to 0. [3] Serial transmission continuation procedure: To continue serial transmission, be sure to read 1 from the TDRE flag to confirm that writing is possible, then write data to TDR, and then clear the TDRE flag to 0. However, the TDRE flag is checked and cleared automatically when the DTC is initiated by a transmit data empty interrupt (TXI) request and writes data to TDR.
Initialization Start transmission
[1]
Read TDRE flag in SSR No
[2]
TDRE = 1 Yes Write transmit data to TDR and clear TDRE flag in SSR to 0
All data transmitted Yes Read TEND flag in SSR
No
[3]
TEND = 1 Yes Clear TE bit in SCR to 0
No
Figure 13.17 Sample Serial Transmission Flowchart
Rev.2.00 Jun. 28, 2007 Page 501 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.6.4
Serial Data Reception (Clocked Synchronous Mode)
Figure 13.18 shows an example of SCI operation for reception in clocked synchronous mode. In serial reception, the SCI operates as described below. 1. The SCI performs internal initialization in synchronization with a synchronization clock input or output, starts receiving data, and stores the receive data in RSR. 2. If an overrun error (when reception of the next data is completed while the RDRF flag in SSR is still set to 1) occurs, the ORER bit in SSR is set to 1. If the RIE bit in SCR is set to 1 at this time, an ERI interrupt request is generated. Receive data is not transferred to RDR. The RDRF flag remains to be set to 1. 3. If reception finishes successfully, the RDRF bit in SSR is set to 1, and receive data is transferred to RDR. If the RIE bit in SCR is set to 1 at this time, an RXI interrupt request is generated. Because the RXI interrupt processing routine reads the receive data transferred to RDR before reception of the next receive data has finished, continuous reception can be enabled.
Synchronization clock Serial data RDRF ORER RXI interrupt request generated RDR data read and RDRF flag cleared to 0 in RXI interrupt processing routine 1 frame RXI interrupt request generated ERI interrupt request generated by overrun error Bit 7 Bit 0 Bit 7 Bit 0 Bit 1 Bit 6 Bit 7
Figure 13.18 Example of Operation for Reception in Clocked Synchronous Mode Transfer cannot be resumed while a receive error flag is set to 1. Accordingly, clear the ORER, FER, PER, and RDRF bits to 0 before resuming reception. Figure 13.19 shows a sample flowchart for serial data reception.
Rev.2.00 Jun. 28, 2007 Page 502 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Initialization Start reception
[1]
[1] SCI initialization: The RxD pin is automatically designated as the receive data input pin. [2] [3] Receive error processing: If a receive error occurs, read the ORER flag in SSR, and after performing the appropriate error processing, clear the ORER flag to 0. Receive cannot be resumed if the ORER flag is set to 1. [4] SCI state check and receive data read: Read SSR and check that the RDRF flag is set to 1, then read the receive data in RDR and clear the RDRF flag to 0. Transition of the RDRF flag from 0 to 1 can also be identified by an RXI interrupt. [5] Serial reception continuation procedure: To continue serial reception, before the MSB (bit 7) of the current frame is received, reading the RDRF flag, reading RDR, and clearing the RDRF flag to 0 should be finished. However, the RDRF flag is cleared automatically when the DTC is initiated by a receive data full interrupt (RXI) and reads data from RDR.
Read ORER flag in SSR Yes
[2]
ORER = 1 No
[3]
Error processing (Continued below)
Read RDRF flag in SSR No
[4]
RDRF = 1 Yes Read receive data in RDR and clear RDRF flag in SSR to 0
No
All data received Yes Clear RE bit in SCR to 0
[5]
[3]
Error processing Overrun error processing Clear ORER flag in SSR to 0
Figure 13.19 Sample Serial Reception Flowchart
Rev.2.00 Jun. 28, 2007 Page 503 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.6.5
Simultaneous Serial Data Transmission and Reception (Clocked Synchronous Mode)
Figure 13.20 shows a sample flowchart for simultaneous serial transmit and receive operations. After initializing the SCI, the following procedure should be used for simultaneous serial data transmit and receive operations. To switch from transmit mode to simultaneous transmit and receive mode, after checking that the SCI has finished transmission and the TDRE and TEND flags are set to 1, clear the TE bit to 0. Then simultaneously set both the TE and RE bits to 1 with a single instruction. To switch from receive mode to simultaneous transmit and receive mode, after checking that the SCI has finished reception, clear the RE bit to 0. Then after checking that the RDRF bit and receive error flags (ORER, FER, and PER) are cleared to 0, simultaneously set both the TE and RE bits to 1 with a single instruction.
Rev.2.00 Jun. 28, 2007 Page 504 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Initialization Start transmission/reception
[1]
Read TDRE flag in SSR No
[2]
[1] SCI initialization: The TxD pin is designated as the transmit data output pin, and the RxD pin is designated as the receive data input pin, enabling simultaneous transmit and receive operations. [2] SCI state check and transmit data write: Read SSR and check that the TDRE flag is set to 1, then write transmit data to TDR and clear the TDRE flag to 0. Transition of the TDRE flag from 0 to 1 can also be identified by a TXI interrupt. [3] Receive error processing: If a receive error occurs, read the ORER flag in SSR, and after performing the appropriate error processing, clear the ORER flag to 0. Reception cannot be resumed if the ORER flag is set to 1. [4] SCI state check and receive data read: Read SSR and check that the RDRF flag is set to 1, then read the receive data in RDR and clear the RDRF flag to 0. Transition of the RDRF flag from 0 to 1 can also be identified by an RXI interrupt.
TDRE = 1 Yes Write transmit data to TDR and clear TDRE flag in SSR to 0
Read ORER flag in SSR Yes [3] Error processing [4]
ORER = 1 No Read RDRF flag in SSR No
RDRF = 1 Yes
[5] Serial transmission/reception continuation procedure: To continue serial transmission/ Read receive data in RDR, and reception, before the MSB (bit 7) of clear RDRF flag in SSR to 0 the current frame is received, finish reading the RDRF flag, reading RDR, and clearing the RDRF flag to No 0. Also, before the MSB (bit 7) of [5] All data received? the current frame is transmitted, read 1 from the TDRE flag to Yes confirm that writing is possible. Then write data to TDR and clear the TDRE flag to 0. Clear TE and RE bits in SCR to 0 However, the TDRE flag is checked and cleared automatically when the DTC is initiated by a transmit data empty interrupt (TXI) request and writes data to TDR. Similarly, the RDRF flag is cleared automatically Note: When switching from transmit or receive operation to when the DTC is initiated by a simultaneous transmit and receive operations, first clear the receive data full interrupt (RXI) and TE bit and RE bit to 0, then set both these bits to 1 reads data from RDR. simultaneously.
Figure 13.20 Sample Flowchart of Simultaneous Serial Transmission and Reception
Rev.2.00 Jun. 28, 2007 Page 505 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.7
Operation in Smart Card Interface Mode
The SCI supports the IC card (smart card) interface, supporting the ISO/IEC 7816-3 (Identification Card) standard, as an extended serial communication interface function. Smart card interface mode can be selected using the appropriate register. 13.7.1 Sample Connection
Figure 13.21 shows a sample connection between the smart card and this LSI. As in the figure, since this LSI communicates with the IC card using a single transmission line, interconnect the TxD and RxD pins and pull up the data transmission line to VCC using a resistor. Setting the RE and TE bits to 1 with the IC card not connected enables closed transmission/reception allowing self diagnosis. To supply the IC card with the clock pulses generated by the SCI, input the SCK pin output to the CLK pin of the IC card. A reset signal can be supplied via the output port of this LSI.
VCC TxD RxD SCK Rx (port) This LSI Main unit of the device to be connected Data line Clock line Reset line I/O CLK RST IC card
Figure 13.21 Pin Connection for Smart Card Interface
Rev.2.00 Jun. 28, 2007 Page 506 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.7.2
Data Format (Except in Block Transfer Mode)
Figure 13.22 shows the data transfer formats in smart card interface mode. * One frame contains 8-bit data and a parity bit in asynchronous mode. * During transmission, at least 2 etu (elementary time unit: time required for transferring one bit) is secured as a guard time after the end of the parity bit before the start of the next frame. * If a parity error is detected during reception, a low error signal is output for 1 etu after 10.5 etu has passed from the start bit. * If an error signal is sampled during transmission, the same data is automatically re-transmitted after at least 2 etu.
In normal transmission/reception Ds D0 D1 D2 D3 D4 D5 D6 D7 Dp
Output from the transmitting station
When a parity error is generated Ds D0 D1 D2 D3 D4 D5 D6 D7 Dp DE
Output from the transmitting station [Legend] Ds: Start bit D0 to D7: Data bits Dp: Parity bit DE: Error signal Output from the receiving station
Figure 13.22 Data Formats in Normal Smart Card Interface Mode For communication with the IC cards of the direct convention and inverse convention types, follow the procedure below.
(Z) A Ds Z D0 Z D1 A D2 Z D3 Z D4 Z D5 A D6 A D7 Z Dp (Z) state
Figure 13.23 Direct Convention (SDIR = SINV = O/E = 0)
Rev.2.00 Jun. 28, 2007 Page 507 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
For the direct convention type, logic levels 1 and 0 correspond to states Z and A, respectively, and data is transferred with LSB-first as the start character, as shown in figure 13.23. Therefore, data in the start character in the figure is H'3B. When using the direct convention type, write 0 to both the SDIR and SINV bits in SCMR. Write 0 to the O/E bit in SMR in order to use even parity, which is prescribed by the smart card standard.
(Z) A Ds Z D7 Z D6 A D5 A D4 A D3 A D2 A D1 A D0 Z Dp (Z) state
Figure 13.24 Inverse Convention (SDIR = SINV = O/E = 1) For the inverse convention type, logic levels 1 and 0 correspond to states A and Z, respectively and data is transferred with MSB-first as the start character, as shown in figure 13.24. Therefore, data in the start character in the figure is H'3F. When using the inverse convention type, write 1 to both the SDIR and SINV bits in SCMR. The parity bit is logic level 0 to produce even parity, which is prescribed by the smart card standard, and corresponds to state Z. Since the SNIV bit of this LSI only inverts data bits D7 to D0, write 1 to the O/E bit in SMR to invert the parity bit in both transmission and reception. 13.7.3 Block Transfer Mode
Block transfer mode is different from normal smart card interface mode in the following respects. * Even if a parity error is detected during reception, no error signal is output. Since the PER bit in SSR is set by error detection, clear the PER bit before receiving the parity bit of the next frame. * During transmission, at least 1 etu is secured as a guard time after the end of the parity bit before the start of the next frame. * Since the same data is not re-transmitted during transmission, the TEND flag is set 11.5 etu after transmission start. * Although the ERS flag in block transfer mode displays the error signal status as in normal smart card interface mode, the flag is always read as 0 because no error signal is transferred.
Rev.2.00 Jun. 28, 2007 Page 508 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.7.4
Receive Data Sampling Timing and Reception Margin
Only the internal clock generated by the on-chip baud rate generator can be used as a transfer clock in smart card interface mode. In this mode, the SCI can operate on a basic clock with a frequency of 32, 64, 372, or 256 times the bit rate according to the BCP1 and BCP0 bit settings (the frequency is always 16 times the bit rate in normal asynchronous mode). At reception, the falling edge of the start bit is sampled using the basic clock in order to perform internal synchronization. Receive data is sampled on the 16th, 32nd, 186th and 128th rising edges of the basic clock so that it can be latched at the middle of each bit as shown in figure 13.25. The reception margin here is determined by the following formula.
M = | (0.5 - 1 2N ) - (L - 0.5) F - | D - 0.5 | (1 + F ) | x 100% N
M: Reception margin (%) N: Ratio of bit rate to clock (N = 32, 64, 372, 256) D: Duty cycle of clock (D = 0 to 1.0) L: Frame length (L = 10) F: Absolute value of clock frequency deviation
Assuming values of F = 0, D = 0.5, and N = 372 in the above formula, the reception margin is determined by the formula below.
M = ( 0.5 - 1 ) x 100% = 49.866% 2 x 372
372 clock cycles 186 clock cycles 0 Internal basic clock Receive data (RxD) Synchronization sampling timing Data sampling timing 185 371 0 185 371 0
Start bit
D0
D1
Figure 13.25 Receive Data Sampling Timing in Smart Card Interface Mode (When Clock Frequency is 372 Times the Bit Rate)
Rev.2.00 Jun. 28, 2007 Page 509 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.7.5
Initialization
Before transmitting and receiving data, initialize the SCI using the following procedure. Initialization is also necessary before switching from transmission to reception and vice versa. 1. 2. 3. 4. 5. Clear the TE and RE bits in SCR to 0. Set the ICR bit of the corresponding pin to 1. Clear the error flags ERS, PER, and ORER in SSR to 0. Set the GM, BLK, O/E, BCP1, BCP0, CKS1, and CKS0 bits in SMR appropriately. Also set the PE bit to 1. Set the SMIF, SDIR, and SINV bits in SCMR appropriately. When the DDR corresponding to the TxD pin is cleared to 0, the TxD and RxD pins are changed from port pins to SCI pins, placing the pins into high impedance state. Set the value corresponding to the bit rate in BRR. Set the CKE1 and CKE0 bits in SCR appropriately. Clear the TIE, RIE, TE, RE, MPIE, and TEIE bits to 0 simultaneously. When the CKE0 bit is set to 1, the SCK pin is allowed to output clock pulses. Set the TIE, RIE, TE, and RE bits in SCR appropriately after waiting for at least a 1-bit interval. Setting the TE and RE bits to 1 simultaneously is prohibited except for self diagnosis.
6. 7.
8.
To switch from reception to transmission, first verify that reception has completed, then initialize the SCI. At the end of initialization, RE and TE should be set to 0 and 1, respectively. Reception completion can be verified by reading the RDRF, PER, or ORER flag. To switch from transmission to reception, first verify that transmission has completed, then initialize the SCI. At the end of initialization, TE and RE should be set to 0 and 1, respectively. Transmission completion can be verified by reading the TEND flag.
Rev.2.00 Jun. 28, 2007 Page 510 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.7.6
Data Transmission (Except in Block Transfer Mode)
Data transmission in smart card interface mode (except in block transfer mode) is different from that in normal serial communication interface mode in that an error signal is sampled and data can be re-transmitted. Figure 13.26 shows the data re-transfer operation during transmission. 1. If an error signal from the receiving end is sampled after one frame of data has been transmitted, the ERS bit in SSR is set to 1. Here, an ERI interrupt request is generated if the RIE bit in SCR is set to 1. Clear the ERS bit to 0 before the next parity bit is sampled. 2. For the frame in which an error signal is received, the TEND bit in SSR is not set to 1. Data is re-transferred from TDR to TSR allowing automatic data retransmission. 3. If no error signal is returned from the receiving end, the ERS bit in SSR is not set to 1. 4. In this case, one frame of data is determined to have been transmitted including re-transfer, and the TEND bit in SSR is set to 1. Here, a TXI interrupt request is generated if the TIE bit in SCR is set to 1. Writing transmit data to TDR starts transmission of the next data. Figure 13.28 shows a sample flowchart for transmission. All the processing steps are automatically performed using a TXI interrupt request to activate the DTC. In transmission, the TEND and TDRE flags in SSR are simultaneously set to 1, thus generating a TXI interrupt request if the TIE bit in SCR has been set to 1. This activates the DTC by a TXI request thus allowing transfer of transmit data if the TXI interrupt request is specified as a source of DTC activation beforehand. The TDRE and TEND flags are automatically cleared to 0 at data transfer by the DTC. If an error occurs, the SCI automatically re-transmits the same data. During re-transmission, TEND remains as 0, thus not activating the DTC. Therefore, the SCI and DTC automatically transmit the specified number of bytes, including re-transmission in the case of error occurrence. However, the ERS flag is not automatically cleared; the ERS flag must be cleared by previously setting the RIE bit to 1 to enable an ERI interrupt request to be generated at error occurrence. When transmitting/receiving data using the DTC, be sure to set and enable the DTC prior to making SCI settings. For DTC settings, see section 7, Data Transfer Controller (DTC).
Rev.2.00 Jun. 28, 2007 Page 511 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
nth transfer frame
Ds D0 D1 D2 D3 D4 D5 D6 D7 Dp DE
Retransfer frame
Ds D0 D1 D2 D3 D4 D5 D6 D7 Dp (DE)
(n + 1) th transfer frame
Ds D0 D1 D2 D3 D4
TDRE
Transfer from TDR to TSR
TEND [2] FER/ERS [1]
Transfer from TDR to TSR
Transfer from TDR to TSR
[4]
[3]
Figure 13.26 Data Re-Transfer Operation in SCI Transmission Mode Note that the TEND flag is set in different timings depending on the GM bit setting in SMR. Figure 13.27 shows the TEND flag set timing.
I/O data TXI (TEND interrupt) GM = 0
Ds
D0
D1
D2
D3
D4
D5
D6
D7
Dp
DE
Guard time
12.5 etu
11.0 etu
GM = 1
[Legend] Ds: D0 to D7: Dp: DE:
Start bit Data bits Parity bit Error signal
Figure 13.27 TEND Flag Set Timing during Transmission
Rev.2.00 Jun. 28, 2007 Page 512 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Start Initialization Start transmission
ERS = 0? Yes
No
Error processing
No
TEND = 1? Yes
Write data to TDR and clear TDRE flag in SSR to 0
No
All data transmitted?
Yes No ERS = 0? Yes
Error processing
No TEND = 1? Yes
Clear TE bit in SCR to 0 End
Figure 13.28 Sample Transmission Flowchart
Rev.2.00 Jun. 28, 2007 Page 513 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.7.7
Serial Data Reception (Except in Block Transfer Mode)
Data reception in smart card interface mode is similar to that in normal serial communication interface mode. Figure 13.29 shows the data re-transfer operation during reception. 1. If a parity error is detected in receive data, the PER bit in SSR is set to 1. Here, an ERI interrupt request is generated if the RIE bit in SCR is set to 1. Clear the PER bit to 0 before the next parity bit is sampled. 2. For the frame in which a parity error is detected, the RDRF bit in SSR is not set to 1. 3. If no parity error is detected, the PER bit in SSR is not set to 1. 4. In this case, data is determined to have been received successfully, and the RDRF bit in SSR is set to 1. Here, an RXI interrupt request is generated if the RIE bit in SCR is set to 1. Figure 13.30 shows a sample flowchart for reception. All the processing steps are automatically performed using an RXI interrupt request to activate the DTC. In reception, setting the RIE bit to 1 allows an RXI interrupt request to be generated when the RDRF flag is set to 1. This activates the DTC by an RXI request thus allowing transfer of receive data if the RXI interrupt request is specified as a source of DTC activation beforehand. The RDRF flag is automatically cleared to 0 at data transfer by the DTC. If an error occurs during reception, i.e., either the ORER or PER flag is set to 1, a transmit/receive error interrupt (ERI) request is generated and the error flag must be cleared. If an error occurs, the DTC is not activated and receive data is skipped, therefore, the number of bytes of receive data specified in the DTC is transferred. Even if a parity error occurs and the PER bit is set to 1 in reception, receive data is transferred to RDR, thus allowing the data to be read. Note: For operations in block transfer mode, see section 13.4, Operation in Asynchronous Mode.
(n + 1) th transfer frame (DE) Ds D0 D1 D2 D3 D4
nth transfer frame Ds D0 D1 D2 D3 D4 D5 D6 D7 Dp DE
Retransfer frame Ds D0 D1 D2 D3 D4 D5 D6 D7 Dp
RDRF [2] PER [1] [3] [4]
Figure 13.29 Data Re-Transfer Operation in SCI Reception Mode
Rev.2.00 Jun. 28, 2007 Page 514 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Start Initialization Start reception
ORER = 0 and PER = 0?
No
Yes No
Error processing
RDRF = 1? Yes
Read data from RDR and clear RDRF flag in SSR to 0
No
All data received?
Yes
Clear RE bit in SCR to 0
Figure 13.30 Sample Reception Flowchart 13.7.8 Clock Output Control
Clock output can be fixed using the CKE1 and CKE0 bits in SCR when the GM bit in SMR is set to 1. Specifically, the minimum width of a clock pulse can be specified. Figure 13.31 shows an example of clock output fixing timing when the CKE0 bit is controlled with GM = 1 and CKE1 = 0.
CKE0
SCK
Given pulse width
Given pulse width
Figure 13.31 Clock Output Fixing Timing
Rev.2.00 Jun. 28, 2007 Page 515 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
At power-on and transitions to/from software standby mode, use the following procedure to secure the appropriate clock duty cycle. * At power-on To secure the appropriate clock duty cycle simultaneously with power-on, use the following procedure. 1. Initially, port input is enabled in the high-impedance state. To fix the potential level, use a pull-up or pull-down resistor. 2. Fix the SCK pin to the specified output using the CKE1 bit in SCR. 3. Set SMR and SCMR to enable smart card interface mode. Set the CKE0 bit in SCR to 1 to start clock output. * At mode switching At transition from smart card interface mode to software standby mode 1. Set the data register (DR) and data direction register (DDR) corresponding to the SCK pin to the values for the output fixed state in software standby mode. 2. Write 0 to the TE and RE bits in SCR to stop transmission/reception. Simultaneously, set the CKE1 bit to the value for the output fixed state in software standby mode. 3. Write 0 to the CKE0 bit in SCR to stop the clock. 4. Wait for one cycle of the serial clock. In the mean time, the clock output is fixed to the specified level with the duty cycle retained. 5. Make the transition to software standby mode. At transition from smart card interface mode to software standby mode 1. Clear software standby mode. 2. Write 1 to the CKE0 bit in SCR to start clock output. A clock signal with the appropriate duty cycle is then generated.
Software standby
Normal operation
Normal operation
[1] [2] [3]
[4] [5]
[6]
[7]
Figure 13.32 Clock Stop and Restart Procedure
Rev.2.00 Jun. 28, 2007 Page 516 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.8
13.8.1
Interrupt Sources
Interrupts in Normal Serial Communication Interface Mode
Table 13.12 shows the interrupt sources in normal serial communication interface mode. A different interrupt vector is assigned to each interrupt source, and individual interrupt sources can be enabled or disabled using the enable bits in SCR. When the TDRE flag in SSR is set to 1, a TXI interrupt request is generated. When the TEND flag in SSR is set to 1, a TEI interrupt request is generated. A TXI interrupt request can activate the DTC to allow data transfer. The TDRE flag is automatically cleared to 0 at data transfer by the DTC. When the RDRF flag in SSR is set to 1, an RXI interrupt request is generated. When the ORER, PER, or FER flag in SSR is set to 1, an ERI interrupt request is generated. An RXI interrupt can activate the DTC to allow data transfer. The RDRF flag is automatically cleared to 0 at data transfer by the DTC. A TEI interrupt is requested when the TEND flag is set to 1 while the TEIE bit is set to 1. If a TEI interrupt and a TXI interrupt are requested simultaneously, the TXI interrupt has priority for acceptance. However, note that if the TDRE and TEND flags are cleared to 0 simultaneously by the TXI interrupt processing routine, the SCI cannot branch to the TEI interrupt processing routine later. Table 13.12 SCI Interrupt Sources
Name ERI RXI TXI TEI Interrupt Source Receive error Receive data full Transmit data empty Transmit end Interrupt Flag ORER, FER, or PER RDRF TDRE TEND DTC Activation Not possible Possible Possible Not possible Low Priority High
Rev.2.00 Jun. 28, 2007 Page 517 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.8.2
Interrupts in Smart Card Interface Mode
Table 13.13 shows the interrupt sources in smart card interface mode. A transmit end (TEI) interrupt request cannot be used in this mode. Table 13.13 SCI Interrupt Sources
Name ERI RXI TXI Interrupt Source Receive error or error signal detection Receive data full Transmit data empty Interrupt Flag ORER, PER, or ERS RDRF TDRE DTC Activation Not possible Possible Possible Low Priority High
Data transmission/reception using the DTC is also possible in smart card interface mode, similar to in the normal SCI mode. In transmission, the TEND and TDRE flags in SSR are simultaneously set to 1, thus generating a TXI interrupt. This activates the DTC by a TXI request thus allowing transfer of transmit data if the TXI request is specified as a source of DTC activation beforehand. The TDRE and TEND flags are automatically cleared to 0 at data transfer by the DTC. If an error occurs, the SCI automatically re-transmits the same data. During re-transmission, the TEND flag remains as 0, thus not activating the DTC. Therefore, the SCI and DTC automatically transmit the specified number of bytes, including re-transmission in the case of error occurrence. However, the ERS flag in SSR, which is set at error occurrence, is not automatically cleared; the ERS flag must be cleared by previously setting the RIE bit in SCR to 1 to enable an ERI interrupt request to be generated at error occurrence. When transmitting/receiving data using the DTC, be sure to set and enable the DTC prior to making SCI settings. For DTC settings, see section 7, Data Transfer Controller (DTC). In reception, an RXI interrupt request is generated when the RDRF flag in SSR is set to 1. This activates the DTC by an RXI request thus allowing transfer of receive data if the RXI request is specified as a source of DTC activation beforehand. The RDRF flag is automatically cleared to 0 at data transfer by the DTC. If an error occurs, the RDRF flag is not set but the error flag is set. Therefore, the DTC is not activated and an ERI interrupt request is issued to the CPU instead; the error flag must be cleared.
Rev.2.00 Jun. 28, 2007 Page 518 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.9
13.9.1
Usage Notes
Module Stop State Setting
Operation of the SCI can be disabled or enabled using the module stop control register. The initial setting is for operation of the SCI to be halted. Register access is enabled by clearing module stop state. For details, see section 18, Power-Down States. 13.9.2 Break Detection and Processing
When framing error detection is performed, a break can be detected by reading the RxD pin value directly. In a break, the input from the RxD pin becomes all 0s, and so the FER flag is set, and the PER flag may also be set. Note that, since the SCI continues the receive operation even after receiving a break, even if the FER flag is cleared to 0, it will be set to 1 again. 13.9.3 Mark State and Break Detection
When the TE bit is 0, the TxD pin is used as an I/O port whose direction (input or output) and level are determined by DR and DDR. This can be used to set the TxD pin to mark state (high level) or send a break during serial data transmission. To maintain the communication line in mark state (the state of 1) until TE is set to 1, set both DDR and DR to 1. Since the TE bit is cleared to 0 at this point, the TxD pin becomes an I/O port, and 1 is output from the TxD pin. To send a break during serial transmission, first set DDR to 1 and DR to 0, and then clear the TE bit to 0. When the TE bit is cleared to 0, the transmitter is initialized regardless of the current transmission state, the TxD pin becomes an I/O port, and 0 is output from the TxD pin. 13.9.4 Receive Error Flags and Transmit Operations (Clocked Synchronous Mode Only)
Transmission cannot be started when a receive error flag (ORER, FER, or RER) is set to 1, even if the TDRE flag is cleared to 0. Be sure to clear the receive error flags to 0 before starting transmission. Note also that the receive error flags cannot be cleared to 0 even if the RE bit is cleared to 0.
Rev.2.00 Jun. 28, 2007 Page 519 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.9.5
Relation between Writing to TDR and TDRE Flag
The TDRE flag in SSR is a status flag which indicates that transmit data has been transferred from TDR to TSR. When the SCI transfers data from TDR to TSR, the TDRE flag is set to 1. Data can be written to TDR irrespective of the TDRE flag status. However, if new data is written to TDR when the TDRE flag is 0, that is, when the previous data has not been transferred to TSR yet, the previous data in TDR is lost. Be sure to write transmit data to TDR after verifying that the TDRE flag is set to 1. 13.9.6 Restrictions on Using DTC
* When the external clock source is used as a synchronization clock, update TDR by the DTC and wait for at least five P clock cycles before allowing the transmit clock to be input. If the transmit clock is input within four clock cycles after TDR modification, the SCI may malfunction (figure 13.33). * When using the DTC to read RDR, be sure to set the receive end interrupt (RXI) as the DTC activation source.
SCK
t
TDRE LSB
Serial data
D0
D1
D2
D3
D4
D5
D6
D7
Note: When external clock is supplied, t must be more than four clock cycles.
Figure 13.33 Sample Transmission using DTC in Clocked Synchronous Mode
Rev.2.00 Jun. 28, 2007 Page 520 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
13.9.7 (1)
SCI Operations during Power-Down State
Transmission
Before specifying the module stop state or making a transition to software standby mode, stop the transmit operations (TE = TIE = TEIE = 0). TSR, TDR, and SSR are reset. The states of the output pins in the module stop state or in software standby mode depend on the port settings, and the pins output a high-level signal after cancellation. If the transition is made during data transmission, the data being transmitted will be undefined. To transmit data in the same transmission mode after cancellation of the power-down state, set the TE bit to 1, read SSR, write to TDR, clear TDRE in this order, and then start transmission. To transmit data in a different transmission mode, initialize the SCI first. Figure 13.34 shows a sample flowchart for transition to software standby mode during transmission. Figures 13.35 and 13.36 show the port pin states during transition to software standby mode. Before specifying the module stop state or making a transition to software standby mode from the transmission mode using DTC transfer, stop all transmit operations (TE = TIE = TEIE = 0). Setting the TE and TIE bits to 1 after cancellation sets the TXI flag to start transmission using the DTC. (2) Reception
Before specifying the module stop state or making a transition to software standby mode, stop the receive operations (RE = 0). RSR, RDR, and SSR are reset. If transition is made during data reception, the data being received will be invalid. To receive data in the same reception mode after cancellation of the power-down state, set the RE bit to 1, and then start reception. To receive data in a different reception mode, initialize the SCI first. Figure 13.37 shows a sample flowchart for transition to software standby mode during reception.
Rev.2.00 Jun. 28, 2007 Page 521 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Transmission
All data transmitted? Yes Read TEND flag in SSR
No
[1]
TEND = 1 Yes TE = 0 [2]
No
[1] Data being transmitted is lost halfway. Data can be normally transmitted from the CPU by setting the TE bit to 1, reading SSR, writing to TDR, and clearing the TDRE bit to 0 after clearing software standby mode; however, if the DTC has been activated, the data remaining in the DTC will be transmitted when both the TE and TIE bits are set to 1. [2] Clear the TIE and TEIE bits to 0 when they are 1. [3] Setting of the module stop state is included.
Make transition to software standby mode Cancel software standby mode
[3]
Change operating mode? Yes Initialization
No
TE = 1
Start transmission
Figure 13.34 Sample Flowchart for Transition to Software Standby Mode during Transmission
Transition to Software standby Transmission end software standby mode canceled mode
Transmission start
TE bit SCK output pin TxD output pin
Port input/output Port input/output
High output
Start SCI TxD output
Stop
Port input/output Port
High output SCI TxD output
Port
Figure 13.35 Port Pin States during Transition to Software Standby Mode (Internal Clock, Asynchronous Transmission)
Rev.2.00 Jun. 28, 2007 Page 522 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Transmission start
Transmission end
Transition to Software standby software standby mode canceled mode
TE bit SCK output pin TxD output pin
Port input/output
Port input/output
Marking output SCI TxD output
Last TxD bit retained
Port input/output Port
High output* SCI TxD output
Port Note: * Initialized in software standby mode
Figure 13.36 Port Pin States during Transition to Software Standby Mode (Internal Clock, Clocked Synchronous Transmission)
Reception
Read RDRF flag in SSR
RDRF = 1 Yes Read receive data in RDR
No
[1]
[1] Data being received will be invalid.
[2] Setting of the module stop state is included. RE = 0 Make transition to software standby mode Cancel software standby mode [2]
Change operating mode? Yes Initialization
No
RE = 1
Start reception
Figure 13.37 Sample Flowchart for Transition to Software Standby Mode during Reception
Rev.2.00 Jun. 28, 2007 Page 523 of 666 REJ09B0311-0200
Section 13 Serial Communication Interface (SCI)
Rev.2.00 Jun. 28, 2007 Page 524 of 666 REJ09B0311-0200
Section 14 A/D Converter
Section 14 A/D Converter
This LSI includes a successive approximation type 10-bit A/D converter that allows up to eight analog input channels to be selected. Figure 14.1 shows a block diagram of the A/D converter.
14.1
* * * *
Features
* * *
* *
10-bit resolution Eight input channels Conversion time: 7.4 s per channel (at 35-MHz operation) Two kinds of operating modes Single mode: Single-channel A/D conversion Scan mode: Continuous A/D conversion on 1 to 4 channels, or 1 to 8 channels Eight data registers A/D conversion results are held in a 16-bit data register for each channel Sample and hold function Three types of conversion start Conversion can be started by software, a conversion start trigger by the 16-bit timer pulse unit (TPU) or 8-bit timer (TMR), or an external trigger signal. Interrupt source A/D conversion end interrupt (ADI) request can be generated. Module stop state specifiable
Rev.2.00 Jun. 28, 2007 Page 525 of 666 REJ09B0311-0200
Section 14 A/D Converter
Module data bus
Bus interface ADDRG ADDRC ADDRD ADDRH ADCSR ADDRA ADDRB ADDRE ADDRF
Internal data bus
AVCC 10-bit A/D
Successive approximation register
Vref
AVSS
AN0 AN1
Multiplexer
+ - Comparator Sample-andhold circuit Control circuit
AN2 AN3 AN4 AN5 AN6 AN7
ADCR
ADTRG0 [Legend] ADCR: ADCSR: ADDRA: ADDRB: ADDRC:
ADI0 interrupt signal Conversion start trigger from the TPU or TMR A/D control register A/D control/status register A/D data register A A/D data register B A/D data register C ADDRD: ADDRE: ADDRF: ADDRG: ADDRH: A/D data register D A/D data register E A/D data register F A/D data register G A/D data register H
Figure 14.1 Block Diagram of A/D Converter
Rev.2.00 Jun. 28, 2007 Page 526 of 666 REJ09B0311-0200
Section 14 A/D Converter
14.2
Input/Output Pins
Table 14.1 shows the pin configuration of the A/D converter. Table 14.1 Pin Configuration
Pin Name Analog input pin 0 Analog input pin 1 Analog input pin 2 Analog input pin 3 Analog input pin 4 Analog input pin 5 Analog input pin 6 Analog input pin 7 A/D external trigger input pin Analog power supply pin Analog ground pin Reference voltage pin Symbol AN0 AN1 AN2 AN3 AN4 AN5 AN6 AN7 I/O Function
Input Analog inputs Input Input Input Input Input Input Input
ADTRG0 Input External trigger input for starting A/D conversion AVCC AVSS Vref Input Analog block power supply Input Analog block ground Input A/D conversion reference voltage
14.3
Register Descriptions
The A/D converter has the following registers. * * * * * * * * * * A/D data register A (ADDRA) A/D data register B (ADDRB) A/D data register C (ADDRC) A/D data register D (ADDRD) A/D data register E (ADDRE) A/D data register F (ADDRF) A/D data register G (ADDRG) A/D data register H (ADDRH) A/D control/status register (ADCSR) A/D control register (ADCR)
Rev.2.00 Jun. 28, 2007 Page 527 of 666 REJ09B0311-0200
Section 14 A/D Converter
14.3.1
A/D Data Registers A to H (ADDRA to ADDRH)
There are eight 16-bit read-only ADDR registers, ADDRA to ADDRH, used to store the results of A/D conversion. The ADDR registers, which store a conversion result for each channel, are shown in table 14.2. The converted 10-bit data is stored in bits 15 to 6. The lower 6-bit data is always read as 0. The data bus between the CPU and the A/D converter has a 16-bit width. The data can be read directly from the CPU. ADDR must not be accessed in 8-bit units and must be accessed in 16-bit units.
Bit Bit Name Initial Value R/W 0 R 0 R 0 R 0 R 0 R 0 R 0 R 0 R 0 R 0 R 15 14 13 12 11 10 9 8 7 6 5 0 R 4 0 R 3 0 R 2 0 R 1 0 R 0 0 R
Table 14.2 Analog Input Channels and Corresponding ADDR Registers
Analog Input Channel AN0 AN1 AN2 AN3 AN4 AN5 AN6 AN7 A/D Data Register Which Stores Conversion Result ADDRA ADDRB ADDRC ADDRD ADDRE ADDRF ADDRG ADDRH
Rev.2.00 Jun. 28, 2007 Page 528 of 666 REJ09B0311-0200
Section 14 A/D Converter
14.3.2
A/D Control/Status Register (ADCSR)
ADCSR controls A/D conversion operations.
Bit Bit Name Initial Value R/W 7 ADF 0 R/(W)* 6 ADIE 0 R/W 5 ADST 0 R/W 4 0 R 3 CH3 0 R/W 2 CH2 0 R/W 1 CH1 0 R/W 0 CH0 0 R/W
Note: * Only 0 can be written to this bit, to clear the flag.
Bit 7
Bit Name ADF
Initial Value 0
R/W
Description
6
ADIE
0
5
ADST
0
4
0
R/(W)* A/D End Flag A status flag that indicates the end of A/D conversion. [Setting conditions] * When A/D conversion ends in single mode * When A/D conversion ends on all specified channels in scan mode [Clearing conditions] * When 0 is written after reading ADF = 1 (When the CPU is used to clear this flag by writing 0 while the corresponding interrupt is enabled, be sure to read the flag after writing 0 to it.) * When the DTC is activated by an ADI interrupt and ADDR is read R/W A/D Interrupt Enable When this bit is set to 1, ADI interrupts by ADF are enabled. R/W A/D Start Clearing this bit to 0 stops A/D conversion, and the A/D converter enters wait state. Setting this bit to 1 starts A/D conversion. In single mode, this bit is cleared to 0 automatically when A/D conversion on the specified channel ends. In scan mode, A/D conversion continues sequentially on the specified channels until this bit is cleared to 0 by software, a reset, or hardware standby mode. R Reserved This is a read-only bit and cannot be modified.
Rev.2.00 Jun. 28, 2007 Page 529 of 666 REJ09B0311-0200
Section 14 A/D Converter
Bit 3 2 1 0
Bit Name CH3 CH2 CH1 CH0
Initial Value 0 0 0 0
R/W R/W R/W R/W R/W
Description Channel Select 3 to 0 Selects analog input together with bits SCANE and SCANS in ADCR. * When SCANE = 0 and SCANS = X 0000: AN0 0001: AN1 0010: AN2 0011: AN3 0100: AN4 0101: AN5 0110: AN6 0111: AN7 1XXX: Setting prohibited * When SCANE = 1 and SCANS = 0 0000: AN0 0001: AN0 and AN1 0010: AN0 to AN2 0011: AN0 to AN3 0100: AN4 0101: AN4 and AN5 0110: AN4 to AN6 0111: AN4 to AN7 1XXX: Setting prohibited * When SCANE = 1 and SCANS = 1 0000: AN0 0001: AN0 and AN1 0010: AN0 to AN2 0011: AN0 to AN3 0100: AN0 to AN4 0101: AN0 to AN5 0110: AN0 to AN6 0111: AN0 to AN7 1XXX: Setting prohibited
[Legend] X: Don't care Note: * Only 0 can be written to this bit, to clear the flag.
Rev.2.00 Jun. 28, 2007 Page 530 of 666 REJ09B0311-0200
Section 14 A/D Converter
14.3.3
A/D Control Register (ADCR)
ADCR enables A/D conversion to be started by an external trigger input.
Bit Bit Name Initial Value R/W 7 TRGS1 0 R/W 6 TRGS0 0 R/W 5 SCANE 0 R/W 4 SCANS 0 R/W 3 CKS1 0 R/W 2 CKS0 0 R/W 1 0 R 0 0 R
Bit 7 6
Bit Name TRGS1 TRGS0
Initial Value 0 0
R/W R/W R/W
Description Timer Trigger Select 1 and 0 These bits select enabling or disabling of the start of A/D conversion by a trigger signal. 00: A/D conversion start by external trigger is disabled 01: A/D conversion start by external trigger from TPU is enabled 10: A/D conversion start by external trigger from TMR is enabled 11: A/D conversion start by the ADTRG0 pin is enabled*
5 4
SCANE SCANS
0 0
R/W R/W
Scan Mode These bits select the A/D conversion operating mode. 0X: Single mode 10: Scan mode. A/D conversion is performed continuously for channels 1 to 4. 11: Scan mode. A/D conversion is performed continuously for channels 1 to 8.
3 2
CKS1 CKS0
0 0
R/W R/W
Clock Select 1 and 0 These bits set the A/D conversion time. Set bits CKS1 and CKS0 only while A/D conversion is stopped (ADST = 0). 00: A/D conversion time = 530 states (max) 01: A/D conversion time = 266 states (max) 10: A/D conversion time = 134 states (max) 11: A/D conversion time = 68 states (max)
Rev.2.00 Jun. 28, 2007 Page 531 of 666 REJ09B0311-0200
Section 14 A/D Converter
Bit 1, 0
Bit Name
Initial Value All 0
R/W R
Description Reserved These are read-only bits and cannot be modified.
[Legend] X: Don't care Note: * To set A/D conversion to start by the ADTRG0 pin, the DDR bit and ICR bit for the corresponding pin should be set to 0 and 1, respectively. For details, see section 8, I/O Ports.
14.4
Operation
The A/D converter operates by successive approximation with 10-bit resolution. It has two operating modes: single mode and scan mode. When changing the operating mode or analog input channel, to prevent incorrect operation, first clear the ADST bit in ADCSR to 0 to halt A/D conversion. The ADST bit can be set to 1 at the same time as the operating mode or analog input channel is changed. 14.4.1 Single Mode
In single mode, A/D conversion is to be performed only once on the analog input of the specified single channel. 1. A/D conversion for the selected channel is started when the ADST bit in ADCSR is set to 1 by software or an external trigger input. 2. When A/D conversion is completed, the A/D conversion result is transferred to the corresponding A/D data register of the channel. 3. When A/D conversion is completed, the ADF bit in ADCSR is set to 1. If the ADIE bit is set to 1 at this time, an ADI interrupt request is generated. 4. The ADST bit remains set to 1 during A/D conversion, and is automatically cleared to 0 when A/D conversion ends. The A/D converter enters wait state. If the ADST bit is cleared to 0 during A/D conversion, A/D conversion stops and the A/D converter enters wait state.
Rev.2.00 Jun. 28, 2007 Page 532 of 666 REJ09B0311-0200
Section 14 A/D Converter
Set* ADIE Set* ADST A/D conversion start Clear* ADF Clear* Set*
Channel 0 (AN0) operation state Channel 1 (AN1) operation state Channel 2 (AN2) operation state Channel 3 (AN3) operation state ADDRA
Waiting for conversion Waiting for conversion
A/D conversion 1
Waiting for conversion
A/D conversion 2
Waiting for conversion
Waiting for conversion
Waiting for conversion
Reading A/D conversion result
Reading A/D conversion result A/D conversion result 2
ADDRB ADDRC
A/D conversion result 1
ADDRD
Note: * indicates the timing of instruction execution by software.
Figure 14.2 Example of A/D Converter Operation (Single Mode, Channel 1 Selected) 14.4.2 Scan Mode
In scan mode, A/D conversion is to be performed sequentially on the analog inputs of the specified channels up to four or eight channels. 1. When the ADST bit in ADCSR is set to 1 by software, TPU, TMR, or an external trigger input, A/D conversion starts on the first channel in the group. Consecutive A/D conversion on a maximum of four channels (SCANE and SCANS = B'10) or on a maximum of eight channels (SCANE and SCANS = B'11) can be selected. When consecutive A/D conversion is performed on four channels, A/D conversion starts on AN4 when CH3 and CH2 = B'01. When consecutive A/D conversion is performed on eight channels, A/D conversion starts on AN0 when CH3 = B'0. 2. When A/D conversion for each channel is completed, the A/D conversion result is sequentially transferred to the corresponding ADDR of each channel.
Rev.2.00 Jun. 28, 2007 Page 533 of 666 REJ09B0311-0200
Section 14 A/D Converter
3. When A/D conversion of all selected channels is completed, the ADF bit in ADCSR is set to 1. If the ADIE bit is set to 1 at this time, an ADI interrupt request is generated. A/D conversion of the first channel in the group starts again. 4. The ADST bit is not cleared automatically, and steps [2] to [3] are repeated as long as the ADST bit remains set to 1. When the ADST bit is cleared to 0, A/D conversion stops and the A/D converter enters wait state. If the ADST bit is later set to 1, A/D conversion starts again from the first channel in the group.
A/D conversion consecutive execution Set*1 ADST Clear*1 Clear*1
ADF Channel 0 (AN0) operation state Channel 1 (AN1) operation state Channel 2 (AN2) operation state Channel 3 (AN3) operation state ADDRA Waiting for conversion A/D conversion 1 A/D conversion time Waiting for conversion A/D conversion 2 A/D conversion 4 Waiting for conversion A/D conversion 5 Waiting for conversion
Waiting for conversion
Waiting for conversion A/D conversion 3
*2
Waiting for conversion
Waiting for conversion
Waiting for conversion Transfer A/D conversion result 1 A/D conversion result 4
ADDRB
A/D conversion result 2
ADDRC
A/D conversion result 3
ADDRD
Notes: 1. indicates the timing of instruction execution by software. 2. Data being converted is ignored.
Figure 14.3 Example of A/D Conversion (Scan Mode, Three Channels (AN0 to AN2) Selected)
Rev.2.00 Jun. 28, 2007 Page 534 of 666 REJ09B0311-0200
Section 14 A/D Converter
14.4.3
Input Sampling and A/D Conversion Time
The A/D converter has a built-in sample-and-hold circuit. The A/D converter samples the analog input when the A/D conversion start delay time (tD) passes after the ADST bit in ADCSR is set to 1, then starts A/D conversion. Figure 14.4 shows the A/D conversion timing. Table 14.3 indicates the A/D conversion time. As indicated in figure 14.4, the A/D conversion time (tCONV) includes tD and the input sampling time (tSPL). The length of tD varies depending on the timing of the write access to ADCSR. The total conversion time therefore varies within the ranges indicated in table 14.3. In scan mode, the values given in table 14.3 apply to the first conversion time. The values given in table 14.4 apply to the second and subsequent conversions. In either case, bits CKS1 and CKS0 in ADCR should be set so that the conversion time is within the ranges indicated by the A/D conversion characteristics.
(1) P Address (2)
Write signal Input sampling timing
ADF tD tSPL tCONV [Legend] (1): ADCSR write cycle (2): ADCSR address A/D conversion start delay time tD: tSPL: Input sampling time tCONV: A/D conversion time
Figure 14.4 A/D Conversion Timing
Rev.2.00 Jun. 28, 2007 Page 535 of 666 REJ09B0311-0200
Section 14 A/D Converter
Table 14.3 A/D Conversion Characteristics (Single Mode)
CKS1 = 0 CKS0 = 0 Min. Typ. Max. Item A/D conversion start delay time Symbol tD 18 515 127 33 530 10 259 63 17 266 6 131 31 9 134 CKS0 = 1 Min. Typ. Max. CKS1 = 1 CKS0 = 0 Min. Typ. Max. CKS0 = 1 Min. Typ. Ma x. 4 67 15 5 68
Input sampling time tSPL A/D conversion time tCONV
Note:
Values in the table are the number of states.
Table 14.4 A/D Conversion Characteristics (Scan Mode)
CKS1 0 CKS0 0 1 1 0 1 Conversion Time (Number of States) 512 (Fixed) 256 (Fixed) 128 (Fixed) 64 (Fixed)
Rev.2.00 Jun. 28, 2007 Page 536 of 666 REJ09B0311-0200
Section 14 A/D Converter
14.4.4
External Trigger Input Timing
A/D conversion can be externally triggered. When the TRGS1 and TRGS0 bits are set to B'11 in ADCR, an external trigger is input from the ADTRG0 pin. A/D conversion starts when the ADST bit in ADCSR is set to 1 on the falling edge of the ADTRG0 pin. Other operations, in both single and scan modes, are the same as when the ADST bit has been set to 1 by software. Figure 14.5 shows the timing.
P
ADTRG0 Internal trigger signal
ADST A/D conversion
Figure 14.5 External Trigger Input Timing
14.5
Interrupt Source
The A/D converter generates an A/D conversion end interrupt (ADI) at the end of A/D conversion. Setting the ADIE bit to 1 when the ADF bit in ADCSR is set to 1 after A/D conversion is completed enables ADI interrupt requests. The data transfer controller (DTC) can be activated by an ADI interrupt. Having the converted data read by the DTC in response to an ADI interrupt enables continuous conversion to be achieved without imposing a load on software. Table 14.5 A/D Converter Interrupt Source
Name ADI0 Interrupt Source A/D conversion end Interrupt Flag ADF DTC Activation Possible
Rev.2.00 Jun. 28, 2007 Page 537 of 666 REJ09B0311-0200
Section 14 A/D Converter
14.6
A/D Conversion Accuracy Definitions
This LSI's A/D conversion accuracy definitions are given below. * Resolution The number of A/D converter digital output codes. * Quantization error The deviation inherent in the A/D converter, given by 1/2 LSB (see figure 14.6). * Offset error The deviation of the analog input voltage value from the ideal A/D conversion characteristic when the digital output changes from the minimum voltage value B'0000000000 (H'000) to B'0000000001 (H'001) (see figure 14.7). * Full-scale error The deviation of the analog input voltage value from the ideal A/D conversion characteristic when the digital output changes from B'1111111110 (H'3FE) to B'1111111111 (H'3FF) (see figure 14.7). * Nonlinearity error The error with respect to the ideal A/D conversion characteristic between the zero voltage and the full-scale voltage. Does not include the offset error, full-scale error, or quantization error (see figure 14.7). * Absolute accuracy The deviation between the digital value and the analog input value. Includes the offset error, full-scale error, quantization error, and nonlinearity error.
Rev.2.00 Jun. 28, 2007 Page 538 of 666 REJ09B0311-0200
Section 14 A/D Converter
Digital output
111 110 101 100 011 010 001 000
Ideal A/D conversion characteristic
Quantization error
1 2 1024 1024
1022 1023 FS 1024 1024 Analog input voltage
Figure 14.6 A/D Conversion Accuracy Definitions
Full-scale error
Digital output
Ideal A/D conversion characteristic
Nonlinearity error Actual A/D conversion characteristic FS Analog input voltage
Offset error
Figure 14.7 A/D Conversion Accuracy Definitions
Rev.2.00 Jun. 28, 2007 Page 539 of 666 REJ09B0311-0200
Section 14 A/D Converter
14.7
14.7.1
Usage Notes
Module Stop State Setting
Operation of the A/D converter can be disabled or enabled using the module stop control register. The initial setting is for operation of the A/D converter to be halted. Register access is enabled by clearing the module stop state. For details, see section 18, Power-Down States. 14.7.2 Permissible Signal Source Impedance
This LSI's analog input is designed so that the conversion accuracy is guaranteed for an input signal for which the signal source impedance is 10 k or less. This specification is provided to enable the A/D converter's sample-and-hold circuit input capacitance to be charged within the sampling time; if the sensor output impedance exceeds 10 k, charging may be insufficient and it may not be possible to guarantee the A/D conversion accuracy. However, if a large capacitance is provided externally for conversion in single mode, the input load will essentially comprise only the internal input resistance of 10 k, and the signal source impedance is ignored. However, since a low-pass filter effect is obtained in this case, it may not be possible to follow an analog signal with a large differential coefficient (e.g., 5 mV/s or greater) (see figure 14.8). When converting a high-speed analog signal or conversion in scan mode, a low-impedance buffer should be inserted.
This LSI Sensor output impedance R 10 k Sensor input Low-pass filter C = 0.1 F (recommended value) Cin = 15 pF 20 pF Equivalent circuit of the A/D converter 10 k
Figure 14.8 Example of Analog Input Circuit
Rev.2.00 Jun. 28, 2007 Page 540 of 666 REJ09B0311-0200
Section 14 A/D Converter
14.7.3
Influences on Absolute Accuracy
Adding capacitance results in coupling with GND, and therefore noise in GND may adversely affect absolute accuracy. Be sure to make the connection to an electrically stable GND such as AVss. Care is also required to insure that filter circuits do not communicate with digital signals on the mounting board, acting as antennas. 14.7.4 Setting Range of Analog Power Supply and Other Pins
If the conditions shown below are not met, the reliability of the LSI may be adversely affected. * Analog input voltage range The voltage applied to analog input pin ANn during A/D conversion should be in the range AVss VAN Vref. * Relation between AVcc, AVss and Vcc, Vss As the relationship between AVcc, AVss and Vcc, Vss, set AVcc = Vcc 0.3 V and AVss = Vss. If the A/D converter is not used, set AVcc = Vcc and AVss = Vss. * Vref setting range The reference voltage at the Vref pin should be set in the range Vref AVcc. 14.7.5 Notes on Board Design
In board design, digital circuitry and analog circuitry should be as mutually isolated as possible, and layout in which digital circuit signal lines and analog circuit signal lines cross or are in close proximity should be avoided as far as possible. Failure to do so may result in incorrect operation of the analog circuitry due to inductance, adversely affecting A/D conversion values. Digital circuitry must be isolated from the analog input pins (AN0 to AN7), analog reference power supply (Vref), and analog power supply (AVcc) by the analog ground (AVss). Also, the analog ground (AVss) should be connected at one point to a stable ground (Vss) on the board.
Rev.2.00 Jun. 28, 2007 Page 541 of 666 REJ09B0311-0200
Section 14 A/D Converter
14.7.6
Notes on Noise Countermeasures
A protection circuit connected to prevent damage due to an abnormal voltage such as an excessive surge at the analog input pins (AN0 to AN7) should be connected between AVcc and AVss as shown in figure 14.9. Also, the bypass capacitors connected to AVcc and the filter capacitor connected to the AN0 to AN7 pins must be connected to AVss. If a filter capacitor is connected, the input currents at the AN0 to AN7 pins are averaged, and so an error may arise. Also, when A/D conversion is performed frequently, as in scan mode, if the current charged and discharged by the capacitance of the sample-and-hold circuit in the A/D converter exceeds the current input via the input impedance (Rin), an error will arise in the analog input pin voltage. Careful consideration is therefore required when deciding the circuit constants.
AVCC
Vref Rin* 2 *1 *1 0.1 F AVSS Notes: Values are reference values. 1. 10 F 0.01 F 100 AN0 to AN7
2. Rin: Input impedance
Figure 14.9 Example of Analog Input Protection Circuit Table 14.6 Analog Pin Specifications
Item Analog input capacitance Permissible signal source impedance Min Max 20 10 Unit pF k
Rev.2.00 Jun. 28, 2007 Page 542 of 666 REJ09B0311-0200
Section 14 A/D Converter
10 k AN0 to AN7 To A/D converter 20 pF
Note: Values are reference values.
Figure 14.10 Analog Input Pin Equivalent Circuit 14.7.7 A/D Input Hold Function in Software Standby Mode
When this LSI enters software standby mode with A/D conversion enabled, the analog inputs are retained, and the analog power supply current is equal to as during A/D conversion. If the analog power supply current needs to be reduced in software standby mode, clear the ADST, TRGS1, and TRGS0 bits all to 0 to disable A/D conversion.
Rev.2.00 Jun. 28, 2007 Page 543 of 666 REJ09B0311-0200
Section 14 A/D Converter
Rev.2.00 Jun. 28, 2007 Page 544 of 666 REJ09B0311-0200
Section 15 D/A Converter
Section 15 D/A Converter
15.1
* * * * * *
Features
8-bit resolution Two output channels Maximum conversion time of 10 s (with 20 pF load) Output voltage of 0 V to Vref D/A output hold function in software standby mode Module stop state specifiable
Module data bus
Bus interface
Internal data bus
Vref 8-bit D/A
DACR01 DADR0 DADR1
AVCC DA1 DA0 AVSS
Control circuit [Legend] DADR0: D/A data register 0 DADR1: D/A data register 1 DACR01: D/A control register 01
Figure 15.1 Block Diagram of D/A Converter
Rev.2.00 Jun. 28, 2007 Page 545 of 666 REJ09B0311-0200
Section 15 D/A Converter
15.2
Input/Output Pins
Table 15.1 shows the pin configuration of the D/A converter. Table 15.1 Pin Configuration
Pin Name Analog power supply pin Analog ground pin Reference voltage pin Analog output pin 0 Analog output pin 1 Symbol AVCC AVSS Vref DA0 DA1 I/O Input Input Input Output Output Function Analog block power supply Analog block ground D/A conversion reference voltage Channel 0 analog output Channel 1 analog output
15.3
Register Descriptions
The D/A converter has the following registers. * D/A data register 0 (DADR0) * D/A data register 1 (DADR1) * D/A control register 01 (DACR01) 15.3.1 D/A Data Registers 0 and 1 (DADR0 and DADR1)
DADR is an 8-bit readable/writable register that stores data to which D/A conversion is to be performed. Whenever analog output is enabled, the values in DADR are converted and output to the analog output pins.
Bit Bit Name Initial Value R/W 0 R/W 0 R/W 0 R/W 0 R/W 0 R/W 0 R/W 0 R/W 0 R/W 7 6 5 4 3 2 1 0
Rev.2.00 Jun. 28, 2007 Page 546 of 666 REJ09B0311-0200
Section 15 D/A Converter
15.3.2
D/A Control Register 01 (DACR01)
DACR01 controls the operation of the D/A converter.
Bit Bit Name Initial Value R/W 7 DAOE1 0 R/W 6 DAOE0 0 R/W 5 DAE 0 R/W 4 1 R 3 1 R 2 1 R 1 1 R 0 1 R
Bit 7
Bit Name DAOE1
Initial Value 0
R/W R/W
Description D/A Output Enable 1 Controls D/A conversion and analog output. 0: Analog output of channel 1 (DA1) is disabled 1: D/A conversion of channel 1 is enabled. Analog output of channel 1 (DA1) is enabled.
6
DAOE0
0
R/W
D/A Output Enable 0 Controls D/A conversion and analog output. 0: Analog output of channel 0 (DA0) is disabled 1: D/A conversion of channel 0 is enabled. Analog output of channel 0 (DA0) is enabled.
5
DAE
0
R/W
D/A Enable Used together with the DAOE0 and DAOE1 bits to control D/A conversion. When this bit is cleared to 0, D/A conversion is controlled independently for channels 0 and 1. When this bit is set to 1, D/A conversion for channels 0 and 1 is controlled together. Output of conversion results is always controlled by the DAOE0 and DAOE1 bits. For details, see table 15.2, Control of D/A Conversion.
4 to 0
All 1
R
Reserved These are read-only bits and cannot be modified.
Rev.2.00 Jun. 28, 2007 Page 547 of 666 REJ09B0311-0200
Section 15 D/A Converter
Table 15.2 Control of D/A Conversion
Bit 5 DAE 0 Bit 7 DAOE1 0 Bit 6 DAOE0 0 1 Description D/A conversion is disabled. D/A conversion of channel 0 is enabled and D/A conversion of channel 1 is disabled. Analog output of channel 0 (DA0) is enabled and analog output of channel 1 (DA1) is disabled. 1 0 D/A conversion of channel 0 is disabled and D/A conversion of channel 1 is enabled. Analog output of channel 0 (DA0) is disabled and analog output of channel 1 (DA1) is enabled. 1 D/A conversion of channels 0 and 1 is enabled. Analog output of channels 0 and 1 (DA0 and DA1) is enabled. 1 0 0 D/A conversion of channels 0 and 1 is enabled. Analog output of channels 0 and 1 (DA0 and DA1) is disabled. 1 D/A conversion of channels 0 and 1 is enabled. Analog output of channel 0 (DA0) is enabled and analog output of channel 1 (DA1) is disabled. 1 0 D/A conversion of channels 0 and 1 is enabled. Analog output of channel 0 (DA0) is disabled and analog output of channel 1 (DA1) is enabled. 1 D/A conversion of channels 0 and 1 is enabled. Analog output of channels 0 and 1 (DA0 and DA1) is enabled.
Rev.2.00 Jun. 28, 2007 Page 548 of 666 REJ09B0311-0200
Section 15 D/A Converter
15.4
Operation
The D/A converter includes D/A conversion circuits for two channels, each of which can operate independently. When the DAOE bit in DACR01 is set to 1, D/A conversion is enabled and the conversion result is output. An operation example of D/A conversion on channel 0 is shown below. Figure 15.2 shows the timing of this operation. 1. Write the conversion data to DADR0. 2. Set the DAOE0 bit in DACR01 to 1 to start D/A conversion. The conversion result is output from the analog output pin DA0 after the conversion time tDCONV has elapsed. The conversion result continues to be output until DADR0 is written to again or the DAOE0 bit is cleared to 0. The output value is expressed by the following formula: Contents of DADR/256 x Vref 3. If DADR0 is written to again, the conversion is immediately started. The conversion result is output after the conversion time tDCONV has elapsed. 4. If the DAOE0 bit is cleared to 0, analog output is disabled.
DADR0 write cycle DACR01 write cycle DADR0 write cycle DACR01 write cycle
P
Address
DADR0
Conversion data 1
Conversion data 2
DAOE0
DA0 High-impedance state tDCONV
Conversion result 1 tDCONV
Conversion result 2
[Legend] tDCONV: D/A conversion time
Figure 15.2 Example of D/A Converter Operation
Rev.2.00 Jun. 28, 2007 Page 549 of 666 REJ09B0311-0200
Section 15 D/A Converter
15.5
15.5.1
Usage Notes
Module Stop State Setting
Operation of the D/A converter can be disabled or enabled using the module stop control register. The initial setting is for operation of the D/A converter to be halted. Register access is enabled by clearing the module stop state. For details, see section 18, Power-Down States. 15.5.2 D/A Output Hold Function in Software Standby Mode
When this LSI enters software standby mode with D/A conversion enabled, the D/A outputs are retained, and the analog power supply current is equal to as during D/A conversion. If the analog power supply current needs to be reduced in software standby mode, clear the ADST, TRGS1, and TRGS0 bits all to 0 to disable D/A conversion.
Rev.2.00 Jun. 28, 2007 Page 550 of 666 REJ09B0311-0200
Section 16 RAM
Section 16 RAM
This LSI has a 24-kbyte on-chip high-speed static RAM. The RAM is connected to the CPU by a 32-bit data bus, enabling one-state access by the CPU to all byte data, word data, and longword data. The on-chip RAM can be enabled or disabled by means of the RAME bit in the system control register (SYSCR). For details on SYSCR, refer to section 3.2.2, System Control Register (SYSCR).
Product Classification ROMless H8SX/1650C RAM Size 24 kbytes RAM Addresses H'FF6000 to H'FFBFFF
Rev.2.00 Jun. 28, 2007 Page 551 of 666 REJ09B0311-0200
Section 16 RAM
Rev.2.00 Jun. 28, 2007 Page 552 of 666 REJ09B0311-0200
Section 17 Clock Pulse Generator
Section 17 Clock Pulse Generator
This LSI has an on-chip clock pulse generator (CPG) that generates the system clock (I), peripheral module clock (P), and external bus clock (B). The clock pulse generator consists of an oscillator, PLL (Phase Locked Loop) circuit, divider, and selector circuit. Figure 17.1 shows a block diagram of the clock pulse generator. Clock frequencies can be changed by the PLL circuit and divider in the CPG. Changing the system clock control register (SCKCR) setting by software can change the clock frequencies. This LSI supports three types of clocks: a system clock provided to the CPU and bus masters, a peripheral module clock provided to the peripheral modules, and an external bus clock provided to the external bus. These clocks can be specified independently. Note, however, that the frequencies of the peripheral clock and external bus clock are lower than that of the system clock.
SCKCR ICK2 to ICK0 EXTAL x 4 EXTAL x 2 Selector System clock (I) EXTAL x 1 (to the CPU and EXTAL x 1/2 bus masters) SCKCR Divider (1/1, 1/2, 1/4, and 1/8) PCK2 to PCK0 1/1 1/2 Peripheral module 1/4 Selector clock (P) 1/8 (to peripheral modules) SCKCR BCK2 to BCK0 1/1 1/2 Selector External bus clock (B) 1/4 (to the B pin) 1/8
EXTAL Oscillator XTAL
PLL circuit
EXTAL x 4
Figure 17.1 Block Diagram of Clock Pulse Generator
Rev.2.00 Jun. 28, 2007 Page 553 of 666 REJ09B0311-0200
Section 17 Clock Pulse Generator
17.1
Register Description
The clock pulse generator has the following register. * System clock control register (SCKCR) 17.1.1 System Clock Control Register (SCKCR)
SCKCR controls B clock output and frequencies of the system, peripheral module, and external bus clocks.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 PSTOP1 0 R/W 7 0 R/W 14 0 R/W 6 PCK2 0 R/W 13 0 R/W 5 PCK1 1 R/W 12 0 R/W 4 PCK0 0 R/W 11 0 R/W 3 0 R/W 10 ICK2 0 R/W 2 BCK2 0 R/W 9 ICK1 1 R/W 1 BCK1 1 R/W 8 ICK0 0 R/W 0 BCK0 0 R/W
Bit 15
Initial Bit Name Value PSTOP1 0
R/W R/W
Description B Output Select Controls B output on PA7. * Normal operation 0: B output 1: Fixed high
14 to 11
All 0
R/W
Reserved These bits are always read as 0. The write value should always be 0.
Rev.2.00 Jun. 28, 2007 Page 554 of 666 REJ09B0311-0200
Section 17 Clock Pulse Generator
Bit 10 9 8
Initial Bit Name Value ICK2 ICK1 ICK0 0 1 0
R/W R/W R/W R/W
Description System Clock (I) Select These bits select the frequency of the system clock provided to the CPU and DTC. The ratio to the input clock is as follows: 000: x 4 001: x 2 010: x 1 011: x 1/2 1XX: Setting prohibited The frequencies of the peripheral module clock and external bus clock change to the same frequency as the system clock if the frequency of the system clock is lower than that of the two clocks.
7
0
R/W
Reserved This bit is always read as 0. The write value should always be 0.
6 5 4
PCK2 PCK1 PCK0
0 1 0
R/W R/W R/W
Peripheral Module Clock (P) Select These bits select the frequency of the peripheral module clock. The ratio to the input clock is as follows: 000: x 4 001: x 2 010: x 1 011: x 1/2 1XX: Setting prohibited The frequency of the peripheral module clock should be lower than that of the system clock. Though these bits can be set so as to make the frequency of the peripheral module clock higher than that of the system clock, the clocks will have the same frequency in reality.
3
0
R/W
Reserved This bit is always read as 0. The write value should always be 0.
Rev.2.00 Jun. 28, 2007 Page 555 of 666 REJ09B0311-0200
Section 17 Clock Pulse Generator
Bit 2 1 0
Initial Bit Name Value BCK2 BCK1 BCK0 0 1 0
R/W R/W R/W R/W
Description External Bus Clock (B) Select These bits select the frequency of the external bus clock. The ratio to the input clock is as follows: 000: x 4 001: x 2 010: x 1 011: x 1/2 1XX: Setting prohibited The frequency of the external bus clock should be lower than that of the system clock. Though these bits can be set so as to make the frequency of the external bus clock higher than that of the system clock, the clocks will have the same frequency in reality.
[Legend] X: Don't care
Rev.2.00 Jun. 28, 2007 Page 556 of 666 REJ09B0311-0200
Section 17 Clock Pulse Generator
17.2
Oscillator
Clock pulses can be supplied by connecting a crystal resonator, or by input of an external clock. 17.2.1 Connecting Crystal Resonator
A crystal resonator can be connected as shown in the example in figure 17.2. Select the damping resistance Rd according to table 17.1. An AT-cut parallel-resonance type should be used. When the clock is provided by connecting a crystal resonator, a crystal resonator having a frequency of 8 to 18 MHz should be connected.
CL1 EXTAL XTAL Rd CL2 CL1 = CL2 = 10 to 22 pF
Figure 17.2 Connection of Crystal Resonator (Example) Table 17.1 Damping Resistance Value
Frequency (MHz) Rd () 8 200 12 0 18 0
Figure 17.3 shows an equivalent circuit of the crystal resonator. Use a crystal resonator that has the characteristics shown in table 17.2.
CL L XTAL C0 Rs
EXTAL AT-cut parallel-resonance type
Figure 17.3 Crystal Resonator Equivalent Circuit
Rev.2.00 Jun. 28, 2007 Page 557 of 666 REJ09B0311-0200
Section 17 Clock Pulse Generator
Table 17.2 Crystal Resonator Characteristics
Frequency (MHz) RS Max. () C0 Max. (pF) 8 80 12 60 7 18 40
17.2.2
External Clock Input
An external clock signal can be input as shown in the examples in figure 17.4. If the XTAL pin is left open, make sure that parasitic capacitance is no more than 10 pF. When the counter clock is input to the XTAL pin, make sure that the external clock is held high in standby mode.
EXTAL XTAL Open
External clock input
(a) XTAL pin left open
EXTAL XTAL
External clock input
(b) Counter clock input on XTAL pin
Figure 17.4 External Clock Input (Examples) For the input conditions of the external clock, refer to table 20.4, Clock Timing, in section 20.3.1, Clock Timing. The input external clock should be from 8 to 18 MHz.
17.3
PLL Circuit
The PLL circuit has the function of multiplying the frequency of the clock from the oscillator by a factor of 4. The frequency multiplication factor is fixed. The phase difference is controlled so that the timing of the rising edge of the internal clock is the same as that of the EXTAL pin signal.
17.4
Frequency Divider
The frequency divider divides the PLL clock to generate a 1/2, 1/4, or 1/8 clock. After bits ICK2 to ICK0, PCK 2 to PCK0, and BCK2 to BCK0 are modified, this LSI operates at the modified frequency.
Rev.2.00 Jun. 28, 2007 Page 558 of 666 REJ09B0311-0200
Section 17 Clock Pulse Generator
17.5
17.5.1
Usage Notes
Notes on Clock Pulse Generator
1. The following points should be noted since the frequency of (I: system clock, P: peripheral module clock, B: external bus clock) supplied to each module changes according to the setting of SCKCR. Select a clock division ratio that is within the operation guaranteed range of clock cycle time tcyc shown in the AC timing of electrical characteristics. For example, the following settings are not permitted under the conditions of 8 MHz I 50 MHz, 8 MHz P 35 MHz, and 8 MHz B 50 MHz: I < 8 MHz, 50 MHz < I, P < 8 MHz, 35 MHz < P, B < 8 MHz, and 50 MHz < B. 2. All the on-chip peripheral modules (except for the DTC) operate on the P. Therefore, note that the time processing of modules such as a timer and SCI differs before and after changing the clock division ratio. In addition, wait time for clearing software standby mode differs by changing the clock division ratio. For details, see section 18.7.3, Setting Oscillation Settling Time after Clearing Software Standby Mode. 3. The relationship among the system clock, peripheral module clock, and external bus clock is I P and I B. In addition, the system clock setting has the highest priority. Accordingly, P or B may have the frequency set by bits ICK2 to ICK0 regardless of the settings of bits PCK2 to PCK0 or BCK2 to BCK0. 4. Figure 17.5 shows the clock modification timing. After a value is written to SCKCR, this LSI waits for the current bus cycle to complete. After the current bus cycle completes, each clock frequency will be modified within one cycle (worst case) of the external input clock.
Rev.2.00 Jun. 28, 2007 Page 559 of 666 REJ09B0311-0200
Section 17 Clock Pulse Generator
One cycle (worst case) after the bus cycle completion External clock I
Bus master
CPU
CPU
CPU
Operating clock specified in SCKCR
Operating clock changed
Figure 17.5 Clock Modification Timing 17.5.2 Notes on Resonator
Since various characteristics related to the resonator are closely linked to the user's board design, thorough evaluation is necessary on the user's part, using the resonator connection examples shown in this section as a reference. As the circuit parameters for the resonator will depend on the floating capacitance of the resonator and the mounting circuit, the parameters should be determined in consultation with the resonator manufacturer. The design must ensure that a voltage exceeding the maximum rating is not applied to the resonator pin. 17.5.3 Notes on Board Design
When using the crystal resonator, place the crystal resonator and its load capacitors as close as possible to the XTAL and EXTAL pins. Other signal lines should be routed away from the oscillation circuit as shown in figure 17.6 to prevent induction from interfering with correct oscillation.
Inhibited Signal A Signal B This LSI CL2 XTAL EXTAL CL1
Figure 17.6 Note on Board Design for Oscillation Circuit
Rev.2.00 Jun. 28, 2007 Page 560 of 666 REJ09B0311-0200
Section 17 Clock Pulse Generator
Figure 17.7 shows the external circuitry recommended for the PLL circuit. Separate PLLVcc and PLLVss from the other Vcc and Vss lines at the board power supply source, and be sure to insert bypass capacitors CPB and CB close to the pins.
Rp: 100 PLLVCC CPB: 0.1 F* PLLVSS VCC CB: 0.1 F* VSS
Note: * CB and CPB are laminated ceramic capacitors.
Figure 17.7 Recommended External Circuitry for PLL Circuit
Rev.2.00 Jun. 28, 2007 Page 561 of 666 REJ09B0311-0200
Section 17 Clock Pulse Generator
Rev.2.00 Jun. 28, 2007 Page 562 of 666 REJ09B0311-0200
Section 18 Power-Down States
Section 18 Power-Down States
This LSI has power consumption reduction functions, such as multi-clock function, module stop function, and transition function to the power-down state.
18.1
Features
* Multi-clock function The frequency division ratio is settable independently for the system clock, peripheral module clock, and external bus clock. * Module stop function The functions for each peripheral module can be stopped to make a transition to the powerdown state. * Transition function to power-down state Transition to the power-down state is possible to stop the CPU, peripheral modules, and oscillator. * Four power-down states Sleep mode All-module-clock-stop mode Software standby mode Hardware standby mode Table 18.1 shows conditions for making a transition to the power-down state, states of the CPU and peripheral modules, and clearing method for each mode. After the reset state, since this LSI operates in normal program execution state, the modules, other than the DTC are stopped.
Rev.2.00 Jun. 28, 2007 Page 563 of 666 REJ09B0311-0200
Section 18 Power-Down States
Table 18.1 Operating States
Operating State Transition condition Cancellation method Oscillator CPU Watchdog timer 8-bit timer Other peripheral modules I/O port Sleep Mode Control register + instruction Interrupt Functions Halted (retained) Functions Functions Functions Functions All-Module-Clock- Software Standby Hardware Stop Mode Mode Standby Mode Control register + instruction Interrupt*2 Functions Halted (retained) Functions Functions* Halted*
1 4
Control register + instruction External interrupt Halted Halted (retained) Halted (retained) Halted (retained) Halted*
1
Pin input
Halted Halted Halted Halted Halted*3 Hi-Z
Retained
Retained
Notes: "Halted (retained)" in the table means that the internal register values are retained and internal operations are suspended. 1. SCI enters the reset state, and other peripheral modules retain their states. 2. External interrupt and some internal interrupts (8-bit timer and watchdog timer) 3. All peripheral modules enter the reset state. 4. "Functions" or "Halted" is selectable through the setting of bits MSTPA11 to MSTPA8 in MSTPCRA. However, pin output is disabled even when "Functions" is selected.
Rev.2.00 Jun. 28, 2007 Page 564 of 666 REJ09B0311-0200
Section 18 Power-Down States
STBY pin = low Reset state STBY pin = high RES pin = low Hardware standby mode
SSBY = 0 RES pin = high SLEEP instruction*3 Sleep mode
All interrupts SLEEP instruction*3 Program execution state Interrupt*1 SLEEP instruction*3
SSBY = 0, ACSE = 1 MSTPCR = H'F[0-F]FFFFFF All-module-clockstop mode
SSBY = 1 External interrupt*2 Software standby mode Program halted state Transition after exception handling Notes: 1. NMI, IRQ0 to IRQ11, 8-bit timer interrupts, and watchdog timer interrupts. The 8-bit timer is valid when bits MSTPCRA11 to MSTPCRA8 are all cleared to 0. 2. NMI and IRQ0 to IRQ11. Note that IRQ is valid only when the corresponding bit in SSIER is set to 1. From any state, a transition to hardware standby mode occurs when STBY is driven low. From any state except for hardware standby mode, a transition to the reset state occurs when RES is driven low. 3. When the SLPIE bit is cleared to 0
Figure 18.1 Mode Transitions
18.2
Register Descriptions
The registers related to the power-down state are shown below. For details on the system clock control register (SCKCR), see section 17.1.1, System Clock Control Register (SCKCR). * * * * Standby control register (SBYCR) Module stop control register A (MSTPCRA) Module stop control register B (MSTPCRB) Module stop control register C (MSTPCRC)
Rev.2.00 Jun. 28, 2007 Page 565 of 666 REJ09B0311-0200
Section 18 Power-Down States
18.2.1
Standby Control Register (SBYCR)
SBYCR controls software standby mode.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 SSBY 0 R/W 7 SLPIE 0 R/W 14 OPE 1 R/W 6 0 R/W 13 0 R/W 5 0 R/W 12 STS4 0 R/W 4 0 R/W 11 STS3 1 R/W 3 0 R/W 10 STS2 1 R/W 2 0 R/W 9 STS1 1 R/W 1 0 R/W 8 STS0 1 R/W 0 0 R/W
Bit 15
Bit Name SSBY
Initial Value 0
R/W R/W
Description Software Standby Specifies the transition mode after executing the SLEEP instruction 0: Shifts to sleep mode after the SLEEP instruction is executed 1: Shifts to software standby mode after the SLEEP instruction is executed This bit does not change when clearing the software standby mode by using external interrupts and shifting to normal operation. For clearing, write 0 to this bit. When the WDT is used as the watchdog timer, the setting of this bit is disabled. In this case, a transition is always made to sleep mode or all-module-clock-stop mode after the SLEEP instruction is executed. This bit should be cleared to 0 when setting the SLPIE bit to 1. Output Port Enable Specifies whether the output of the address bus and bus control signals (CS0 to CS7, AS, RD, HWR, and LWR) is retained or set to the high-impedance state in software standby mode. 0: In software standby mode, address bus and bus control signals are high-impedance 1: In software standby mode, address bus and bus control signals retain output state
14
OPE
1
R/W
Rev.2.00 Jun. 28, 2007 Page 566 of 666 REJ09B0311-0200
Section 18 Power-Down States
Bit 13
Bit Name
Initial Value 0
R/W R/W
Description Reserved This bit is always read as 0. The write value should always be 0. Standby Timer Select 4 to 0 These bits select the time the MCU waits for the clock to settle when software standby mode is cleared by an external interrupt. With a crystal resonator, refer to table 18.2 and make a selection according to the operating frequency so that the standby time is at least equal to the oscillation settling time. With an external clock, a PLL circuit settling time is necessary. Refer to table 18.2 to set the standby time. While oscillation is being settled, the timer is counted on the P clock frequency. Careful consideration is required in multi-clock mode. 00000: Reserved 00001: Reserved 00010: Reserved 00011: Reserved 00100: Reserved 00101: Standby time = 64 states 00110: Standby time = 512 states 00111: Standby time = 1024 states 01000: Standby time = 2048 states 01001: Standby time = 4096 states 01010: Standby time = 16384 states 01011: Standby time = 32768 states 01100: Standby time = 65536 states 01101: Standby time = 131072 states 01110: Standby time = 262144 states 01111: Standby time = 524288 states 1XXXX: Reserved
12 11 10 9 8
STS4 STS3 STS2 STS1 STS0
0 1 1 1 1
R/W R/W R/W R/W R/W
Rev.2.00 Jun. 28, 2007 Page 567 of 666 REJ09B0311-0200
Section 18 Power-Down States
Bit 7
Bit Name SLPIE
Initial Value 0
R/W R/W
Description Sleep Instruction Exception Handling Enable Selects whether the execution of a SLEEP instruction causes sleep instruction exception handling or causes a transition to the power-down state. 0: The execution of a SLEEP instruction causes a transition to the power-down state. 1: The execution of a SLEEP instruction initiates sleep instruction exception handling. After execution of the sleep instruction exception handling, this bit remains set to 1. Writing 0 clears this bit.
6 to 0
All 0
R/W
Reserved These bits are always read as 0. The write value should always be 0.
Rev.2.00 Jun. 28, 2007 Page 568 of 666 REJ09B0311-0200
Section 18 Power-Down States
18.2.2
Module Stop Control Registers A and B (MSTPCRA and MSTPCRB)
MSTPCRA and MSTPCRB control module stop function. Setting a bit to 1 makes the corresponding module enter the module stop state, while clearing the bit to 0 clears the module stop state. * MSTPCRA
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 ACSE 0 R/W 7 MSTPA7 1 R/W 14 MSTPA14 0 R/W 6 MSTPA6 1 R/W 13 MSTPA13 0 R/W 5 MSTPA5 1 R/W 12 MSTPA12 0 R/W 4 MSTPA4 1 R/W 11 MSTPA11 1 R/W 3 MSTPA3 1 R/W 10 MSTPA10 1 R/W 2 MSTPA2 1 R/W 9 MSTPA9 1 R/W 1 MSTPA1 1 R/W 8 MSTPA8 1 R/W 0 MSTPA0 1 R/W
* MSTPCRB
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 MSTPB15 1 R/W 7 MSTPB7 1 R/W 14 MSTPB14 1 R/W 6 MSTPB6 1 R/W 13 MSTPB13 1 R/W 5 MSTPB5 1 R/W 12 MSTPB12 1 R/W 4 MSTPB4 1 R/W 11 MSTPB11 1 R/W 3 MSTPB3 1 R/W 10 MSTPB10 1 R/W 2 MSTPB2 1 R/W 9 MSTPB9 1 R/W 1 MSTPB1 1 R/W 8 MSTPB8 1 R/W 0 MSTPB0 1 R/W
Rev.2.00 Jun. 28, 2007 Page 569 of 666 REJ09B0311-0200
Section 18 Power-Down States
* MSTPCRA
Bit 15 Bit Name ACSE Initial Value 0 R/W R/W Module All-Module-Clock-Stop Mode Enable Enables/disables all-module-clock-stop mode to reduce current consumption by stopping the bus controller and I/O ports operations when the CPU executes the SLEEP instruction after the module stop state has been set for all the on-chip peripheral modules controlled by MSTPCR. 0: All-module-clock-stop mode disabled 1: All-module-clock-stop mode enabled 14 13 12 11 10 9 8 7 6 5 4 MSTPA14 0 MSTPA13 0 MSTPA12 0 MSTPA11 1 MSTPA10 1 MSTPA9 MSTPA8 MSTPA7 MSTPA6 MSTPA5 MSTPA4 1 1 1 1 1 1 R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W Reserved These bits are always read as 0. The write value should always be 0. Data transfer controller (DTC) Reserved These bits are always read as 1. The write value should always be 1. 8-bit timer (TMR_3 and TMR_2) 8-bit timer (TMR_1 and TMR_0) Reserved These bits are always read as 1. The write value should always be 1. D/A converter (channels 1 and 0) Reserved This bit is always read as 1. The write value should always be 1. 3 2 1 0 MSTPA3 MSTPA2 MSTPA1 MSTPA0 1 1 1 1 R/W R/W R/W R/W A/D converter (unit 0) Reserved These bits are always read as 1. The write value should always be 1. 16-bit timer pulse unit (TPU channels 5 to 0)
Rev.2.00 Jun. 28, 2007 Page 570 of 666 REJ09B0311-0200
Section 18 Power-Down States
* MSTPCRB
Bit 15 14 13 12 11 Bit Name Initial Value R/W R/W R/W R/W R/W R/W Module Programmable pulse generator (PPG) Reserved These bits are always read as 1. The write value should always be 1. Serial communication interface_4 (SCI_4) Reserved This bit is always read as 1. The write value should always be 1. 10 9 8 7 6 5 4 3 2 1 0 MSTPB10 1 MSTPB9 MSTPB8 MSTPB7 MSTPB6 MSTPB5 MSTPB4 MSTPB3 MSTPB2 MSTPB1 MSTPB0 1 1 1 1 1 1 1 1 1 1 R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W Serial communication interface_2 (SCI_2) Serial communication interface_1 (SCI_1) Serial communication interface_0 (SCI_0) Reserved These bits are always read as 1. The write value should always be 1.
MSTPB15 1 MSTPB14 1 MSTPB13 1 MSTPB12 1 MSTPB11 1
Rev.2.00 Jun. 28, 2007 Page 571 of 666 REJ09B0311-0200
Section 18 Power-Down States
18.2.3
Module Stop Control Register C (MSTPCRC)
When bits MSTPC2 to MSTPC0 are set to 1, the corresponding on-chip RAM stops. Do not set the corresponding MSTPC2 to MSTPC0 bits to 1 while accessing on-chip RAM.
Bit Bit Name Initial Value R/W Bit Bit Name Initial Value R/W 15 MSTPC15 1 R/W 7 MSTPC7 0 R/W 14 MSTPC14 1 R/W 6 MSTPC6 0 R/W 13 MSTPC13 1 R/W 5 MSTPC5 0 R/W 12 MSTPC12 1 R/W 4 MSTPC4 0 R/W 11 MSTPC11 1 R/W 3 MSTPC3 0 R/W 10 MSTPC10 1 R/W 2 MSTPC2 0 R/W 9 MSTPC9 1 R/W 1 MSTPC1 0 R/W 8 MSTPC8 1 R/W 0 MSTPC0 0 R/W
Bit 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
Bit Name
Initial Value
R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W R/W
Module Reserved These bits are always read as 1. The write value should always be 1.
MSTPC15 1 MSTPC14 1 MSTPC13 1 MSTPC12 1 MSTPC11 1 MSTPC10 1 MSTPC9 MSTPC8 MSTPC7 MSTPC6 MSTPC5 MSTPC4 MSTPC3 MSTPC2 MSTPC1 MSTPC0 1 1 0 0 0 0 0 0 0 0
Reserved These bits are always read as 0. The write value should always be 0.
On-chip RAM_2 (H'FFF6000 to H'FFF7FFF) On-chip RAM_1 (H'FFF8000 to H'FFF9FFF) On-chip RAM_0 (H'FFFA000 to H'FFFBFFF)
Rev.2.00 Jun. 28, 2007 Page 572 of 666 REJ09B0311-0200
Section 18 Power-Down States
18.3
Multi-Clock Function
When bits ICK2 to ICK0, PCK2 to PCK0, and BCK2 to BCK0 in SCKCR are set, the clock frequency changes at the end of the bus cycle. The CPU and bus masters operate on the operating clock specified by bits ICK2 to ICK0. The peripheral modules operate on the operating clock specified by bits PCK2 to PCK0. The external bus clock operates on the operating clock specified by bits BCK2 to BCK0. Even if the frequencies specified by bits PCK2 to PCK0 and BCK2 to BCK0 are higher than the frequency specified by bits ICK2 to ICK0, the specified values are not reflected in the peripheral module and external bus clocks. The peripheral module and external bus clocks are restricted to the operating clock specified by bits ICK2 to ICK0.
18.4
Module Stop Function
Module stop function can be set for individual on-chip peripheral modules. When the corresponding MSTP bit in MSTPCRA, MSTPCRB, or MSTPCRC is set to 1, module operation stops at the end of the bus cycle and a transition is made to the module stop state. The CPU continues operating independently. When the corresponding MSTP bit is cleared to 0, the module stop state is cleared and the module starts operating at the end of the bus cycle. In the module stop state, the internal states of modules other than the SCI are retained. After the reset state is cleared, all modules other than the DTC and on-chip RAM are in the module stop state. The registers of the module for which the module stop state is selected cannot be read from or written to.
Rev.2.00 Jun. 28, 2007 Page 573 of 666 REJ09B0311-0200
Section 18 Power-Down States
18.5
18.5.1
Sleep Mode
Transition to Sleep Mode
When the SLEEP instruction is executed when the SSBY bit in SBYCR is 0, the CPU enters sleep mode. In sleep mode, CPU operation stops but the contents of the CPU's internal registers are retained. Other peripheral functions do not stop. 18.5.2 Clearing Sleep Mode
Sleep mode is exited by any interrupt, signals on the RES or STBY pin, and a reset caused by a watchdog timer overflow. 1. Clearing by interrupt When an interrupt occurs, sleep mode is exited and interrupt exception processing starts. Sleep mode is not exited if the interrupt is disabled, or interrupts other than NMI are masked by the CPU. 2. Clearing by RES pin Setting the RES pin level low selects the reset state. After the stipulated reset input duration, driving the RES pin high makes the CPU start the reset exception processing. 3. Clearing by STBY pin When the STBY pin level is driven low, a transition is made to hardware standby mode. 4. Clearing by reset caused by watchdog timer overflow Sleep mode is exited by an internal reset caused by a watchdog timer overflow.
Rev.2.00 Jun. 28, 2007 Page 574 of 666 REJ09B0311-0200
Section 18 Power-Down States
18.6
All-Module-Clock-Stop Mode
When the ACSE bit is set to 1 and all modules controlled by MSTPCR are stopped (MSTPCRA, MSTPCRB = H'FFFFFFFF), or all modules except for the 8-bit timer are stopped (MSTPCRA, MSTPCRB = H'F[0 to F]FFFFFF), executing a SLEEP instruction with the SSBY bit in SBYCR cleared to 0 will cause all modules (except for the 8-bit timer* and watchdog timer), the bus controller, and the I/O ports to stop operating, and to make a transition to all-module-clock-stop mode at the end of the bus cycle. All-module-clock-stop mode is cleared by an external interrupt (NMI or IRQ0 to IRQ11 pins), RES pin input, or an internal interrupt (8-bit timer* or watchdog timer), and the CPU returns to the normal program execution state via the exception handling state. All-module-clock-stop mode is not cleared if interrupts are disabled, if interrupts other than NMI are masked on the CPU side, or if the relevant interrupt is designated as a DTC activation source. When the STBY pin is driven low, a transition is made to hardware standby mode. Note: * Operation or halting of the 8-bit timer can be selected by bits MSTPA11 to MSTPA8 in MSTPCRA.
18.7
18.7.1
Software Standby Mode
Transition to Software Standby Mode
If a SLEEP instruction is executed when the SSBY bit in SBYCR is set to 1, software standby mode is entered. In this mode, the CPU, on-chip peripheral functions, and oscillator all stop. However, the contents of the CPU's internal registers, on-chip RAM data, and the states of on-chip peripheral functions other than the SCI, and the states of the I/O ports, are retained. Whether the address bus and bus control signals are placed in the high-impedance state or retain the output state can be specified by the OPE bit in SBYCR. In this mode the oscillator stops, allowing power consumption to be significantly reduced. If the WDT is used as a watchdog timer, it is impossible to make a transition to software standby mode. The WDT should be stopped before the SLEEP instruction execution.
Rev.2.00 Jun. 28, 2007 Page 575 of 666 REJ09B0311-0200
Section 18 Power-Down States
18.7.2
Clearing Software Standby Mode
Software standby mode is cleared by an external interrupt (NMI pin, or pins IRQ0 to IRQ11*), or by means of the RES pin or STBY pin. 1. Clearing by interrupt When an NMI or IRQ0 to IRQ11* interrupt request signal is input, clock oscillation starts, and after the elapse of the time set in bits STS4 to STS0 in SBYCR, stable clocks are supplied to the entire LSI, software standby mode is cleared, and interrupt exception handling is started. When clearing software standby mode with an IRQ0 to IRQ11* interrupt, set the corresponding enable bit to 1 and ensure that no interrupt with a higher priority than interrupts IRQ0 to IRQ11* is generated. Software standby mode cannot be cleared if the interrupt has been masked on the CPU side or has been designated as a DTC activation source. Note: * By setting the SSIn bit in SSIER to 1, IRQ0 to IRQ11 can be used as a software standby mode clearing source. 2. Clearing by RES pin When the RES pin is driven low, clock oscillation is started. At the same time as clock oscillation starts, clocks are supplied to the entire LSI. Note that the RES pin must be held low until clock oscillation settles. When the RES pin goes high, the CPU begins reset exception handling. 3. Clearing by STBY pin When the STBY pin is driven low, a transition is made to hardware standby mode. 18.7.3 Setting Oscillation Settling Time after Clearing Software Standby Mode
Bits STS4 to STS0 in SBYCR should be set as described below. 1. Using a crystal resonator Set bits STS4 to STS0 so that the standby time is at least equal to the oscillation settling time. Table 18.2 shows the standby times for operating frequencies and settings of bits STS4 to STS0. 2. Using an external clock A PLL circuit settling time is necessary. Refer to table 18.2 to set the standby time.
Rev.2.00 Jun. 28, 2007 Page 576 of 666 REJ09B0311-0200
Section 18 Power-Down States
Table 18.2 Oscillation Settling Time Settings
Standby STS4 STS3 STS2 STS1 STS0 Time 0 0 0 0 0 1 1 0 1 1 0 0 1 1 0 1 1 0 0 0 1 1 0 1 1 0 0 1 1 0 1 1 0 0 0 0 Reserved Reserved Reserved Reserved Reserved 64 512 1024 2048 4096 16384 32768 65536 131072 262144 524288 Reserved P* [MHz] 35 1.8 14.6 29.3 58.5 0.12 0.47 0.94 1.87 3.74 7.49 14.98 25 2.6 20.5 41.0 81.9 0.16 0.66 1.31 2.62 5.24 10.49 20.97 20 3.2 25.6 51.2 102.4 0.20 0.82 1.64 3.28 6.55 13.11 26.21 ms Unit s
: Recommended time setting when using a crystal resonator. : Recommended time setting when using an external clock. Note: * P is the output from the peripheral module frequency divider.
Rev.2.00 Jun. 28, 2007 Page 577 of 666 REJ09B0311-0200
Section 18 Power-Down States
Standby STS4 STS3 STS2 STS1 STS0 Time 0 0 0 0 0 1 1 0 1 1 0 0 1 1 0 1 1 0 0 0 1 1 0 1 1 0 0 1 1 0 1 1 0 0 0 0 Reserved Reserved Reserved Reserved Reserved 64 512 1024 2048 4096 16384 32765 65536 131072 262144 524288 Reserved
P* [MHz] 13 4.9 39.4 78.8 157.5 0.32 1.26 2.52 5.04 10.08 20.16 40.33 10 6.4 51.2 102.4 204.8 0.41 1.64 3.28 6.55 13.11 26.21 52.43 8 8.0 64.0 128.0 256.0 0.51 2.05 4.10 8.19 16.38 32.77 65.54 ms Unit s
: Recommended time setting when using a crystal resonator. : Recommended time setting when using an external clock. Note: * is the output from the peripheral module frequency divider.
Rev.2.00 Jun. 28, 2007 Page 578 of 666 REJ09B0311-0200
Section 18 Power-Down States
18.7.4
Software Standby Mode Application Example
Figure 18.2 shows an example in which a transition is made to software standby mode at the falling edge on the NMI pin, and software standby mode is cleared at the rising edge on the NMI pin. In this example, an NMI interrupt is accepted with the NMIEG bit in INTCR cleared to 0 (falling edge specification), then the NMIEG bit is set to 1 (rising edge specification), the SSBY bit is set to 1, and a SLEEP instruction is executed, causing a transition to software standby mode. Software standby mode is then cleared at the rising edge on the NMI pin.
Oscillator
I
NMI
NMIEG
SSBY
NMI exception handling NMIEG = 1 SSBY = 1
Software standby mode (power-down mode)
Oscillation settling time tOSC2
NMI exception handling
SLEEP instruction
Figure 18.2 Software Standby Mode Application Example
Rev.2.00 Jun. 28, 2007 Page 579 of 666 REJ09B0311-0200
Section 18 Power-Down States
18.8
18.8.1
Hardware Standby Mode
Transition to Hardware Standby Mode
When the STBY pin is driven low, a transition is made to hardware standby mode from any mode. In hardware standby mode, all functions enter the reset state and stop operation, resulting in a significant reduction in power consumption. As long as the prescribed voltage is supplied, on-chip RAM data is retained. I/O ports are set to the high-impedance state. In order to retain on-chip RAM data, the RAME bit in SYSCR should be cleared to 0 before driving the STBY pin low. Do not change the state of the mode pins (MD2 to MD0) while this LSI is in hardware standby mode. 18.8.2 Clearing Hardware Standby Mode
Hardware standby mode is cleared by means of the STBY pin and the RES pin. When the STBY pin is driven high while the RES pin is low, the reset state is entered and clock oscillation is started. Ensure that the RES pin is held low until clock oscillation settles (for details on the oscillation settling time, refer to table 18.2). When the RES pin is subsequently driven high, a transition is made to the program execution state via the reset exception handling state. 18.8.3 Hardware Standby Mode Timing
Figure 18.3 shows an example of hardware standby mode timing. When the STBY pin is driven low after the RES pin has been driven low, a transition is made to hardware standby mode. Hardware standby mode is cleared by driving the STBY pin high, waiting for the oscillation settling time, then changing the RES pin from low to high.
Oscillator
RES
STBY Oscillation Reset settling time exception handling
Figure 18.3 Hardware Standby Mode Timing
Rev.2.00 Jun. 28, 2007 Page 580 of 666 REJ09B0311-0200
Section 18 Power-Down States
18.8.4
Timing Sequence at Power-On
Figure 18.4 shows the timing sequence at power-on. At power-on, the RES pin must be driven low with the STBY pin driven high for a given time in order to clear the reset state. To enter hardware standby mode immediately after power-on, drive the STBY pin low after exiting the reset state. For details on clearing hardware standby mode, see section 18.8.3, Hardware Standby Mode Timing.
1 Power supply
RES 2 STBY Reset state
3 Hardware standby mode
Figure 18.4 Timing Sequence at Power-On
Rev.2.00 Jun. 28, 2007 Page 581 of 666 REJ09B0311-0200
Section 18 Power-Down States
18.9
Sleep Instruction Exception Handling
Sleep instruction exception handling is exception handling initiated by the execution of a SLEEP instruction. Sleep instruction exception handling is always accepted while the program is in execution. When the SLPIE bit is set to 0, the execution of a SLEEP instruction does not initiate sleep instruction exception handling. Instead, the CPU enters the power-down state. After this, generation of an exception handling request that cancels the power-down state causes the powerdown state to be canceled, after which the CPU starts to handle the exception. When the SLPIE bit is set to 1, sleep instruction exception handling starts after the execution of a SLEEP instruction. Transitions to the power-down state are inhibited when sleep instruction exception handling is initiated, and the CPU immediately starts sleep instruction exception handling. When a SLEEP instruction is executed while the SLPIE bit is cleared to 0, a transition is made to the power-down state. The power-down state is canceled by a canceling factor interrupt (see figure 18.5). When a canceling factor interrupt is generated immediately before the execution of a SLEEP instruction, exception handling for the interrupt starts. When execution returns from the exception service routine, the SLEEP instruction is executed to enter the power-down state. In this case, the power-down state is not canceled until the next canceling factor interrupt is generated (see figure 18.6). When the SLPIE bit is set to 1 in the service routine for a canceling factor interrupt so that the execution of a SLEEP instruction will produce sleep instruction exception handling, the operation of the system is as shown in figure 18.7. Even if a canceling factor interrupt is generated immediately before the SLEEP instruction is executed, sleep instruction exception handling is initiated by execution of the SLEEP instruction. Therefore, the CPU executes the instruction that follows the SLEEP instruction after sleep instruction exception and exception service routine without shifting to the power-down state. When the SLPIE bit is set to 1 to start sleep exception handling, clear the SSBY bit in SBYCR to 0.
Rev.2.00 Jun. 28, 2007 Page 582 of 666 REJ09B0311-0200
Section 18 Power-Down States
SLPIE = 0 Instruction before SLEEP instruction
SLEEP instruction executed (SLPIE = 0) Power-down state Yes Canceling factor interrupt No Interrupt handling RTE instruction executed Transition by exception handling
Instruction after SLEEP instruction
Figure 18.5 When Canceling Factor Interrupt is Generated after SLEEP Instruction Execution
SLPIE = 0 Instruction before SLEEP instruction
Yes Canceling factor interrupt No RTE instruction executed SLEEP instruction executed (SLPIE = 0) Return from the powerdown state after the next canceling factor interrupt is generated Power-down state Yes Canceling factor interrupt No
Transition by exception handling
Interrupt handling
Transition by exception handling
Interrupt handling RTE instruction executed
Instruction after SLEEP instruction
Figure 18.6 When Canceling Factor Interrupt is Generated before SLEEP Instruction Execution (Sleep Instruction Exception Handling Not Initiated)
Rev.2.00 Jun. 28, 2007 Page 583 of 666 REJ09B0311-0200
Section 18 Power-Down States
SLPIE = 0 Instruction before SLEEP instruction
Yes Canceling factor interrupt No
Transition by exception handling
Interrupt handling RTE instruction executed
SLPIE = 1 SSBY = 0
SLEEP instruction executed (SLPIE = 1)
Sleep instruction exceotion handling
Transition by exception handling Vector Number 18 Exception servise routine RTE instruction executed
Instruction after SLEEP instruction
Figure 18.7 When Canceling Factor Interrupt is Generated before SLEEP Instruction Execution (Sleep Instruction Exception Handling Initiated)
Rev.2.00 Jun. 28, 2007 Page 584 of 666 REJ09B0311-0200
Section 18 Power-Down States
18.10
B Clock Output Control
Output of the B clock can be controlled by bits PSTOP1 and POSEL1 in SCKCR, and DDR for the corresponding PA7 pin. Clearing both bits PSTOP1 and POSEL1 to 0 enables the B clock output on the PA7 pin. When bit PSTOP1 is set to 1, the B clock output stops at the end of the bus cycle, and the B clock output goes high. When DDR for the PA7 pin is cleared to 0, the B clock output is disabled and the pin becomes an input port. Tables 18.3 shows the states of the B pin in each processing state. Table 18.3 B Pin (PA7) State in Each Processing State
Register Setting Value DDR 0 1 1 1 PSTOP1 POSEL1 Normal Operating Sleep State Mode Hi-Z B output Setting prohibited High Hi-Z B output Setting prohibited High AllSoftware ModuleStandby Mode ClockStop Mode OPE = 0 OPE = 1 Hi-Z B output Setting prohibited High Hi-Z High Hi-Z High Hardware Standby Mode Hi-Z Hi-Z
X 0 0 1
X 0 1 X
Setting Setting Setting prohibited prohibited prohibited High High Hi-Z
Rev.2.00 Jun. 28, 2007 Page 585 of 666 REJ09B0311-0200
Section 18 Power-Down States
18.11
Usage Notes
18.11.1 I/O Port Status In software standby mode, the I/O port states are retained. Therefore, there is no reduction in current consumption for the output current when a high-level signal is output. 18.11.2 Current Consumption during Oscillation Settling Standby Period Current consumption increases during the oscillation settling standby period. 18.11.3 DTC Module Stop Depending on the operating state of the DTC, bit MSTPA12 may not be set to 1. Setting of the DTC module stop state should be carried out only when the DTC is not activated. For details, see section 7, Data Transfer Controller (DTC). 18.11.4 On-Chip Peripheral Module Interrupts Relevant interrupt operations cannot be performed in the module stop state. Consequently, if module stop state is entered when an interrupt has been requested, it will not be possible to clear the CPU interrupt source or the DTC activation source. Interrupts should therefore be disabled before entering the module stop state. 18.11.5 Writing to MSTPCRA, MSTPCRB, and MSTPCRC MSTPCRA, MSTPCRB, and MSTPCRC should only be written to by the CPU.
Rev.2.00 Jun. 28, 2007 Page 586 of 666 REJ09B0311-0200
Section 19 List of Registers
Section 19 List of Registers
The register list gives information on the on-chip I/O register addresses, how the register bits are configured, and the register states in each operating mode. The information is given as shown below. 1. * * * * Register addresses (address order) Registers are listed from the lower allocation addresses. Registers are classified according to functional modules. The number of Access Cycles indicates the number of states based on the specified reference clock. For details, see section 6.12.1, Access to Internal Address Space. Undefined and reserved addresses cannot be accessed. Do not access these addresses; otherwise, the operation when accessing these bits and subsequent operations cannot be guaranteed. Register bits Bit configurations of the registers are listed in the same order as the register addresses. Reserved bits are indicated by in the bit name column. Space in the bit name field indicates that the entire register is allocated to either the counter or data. For the registers of 16 or 32 bits, the MSB is listed first. Byte configuration description order is subject to big endian. Register states in each operating mode Register states are listed in the same order as the register addresses. For the initialized state of each bit, refer to the register description in the corresponding section. The register states shown here are for the basic operating modes. If there is a specific reset for an on-chip peripheral module, refer to the section on that on-chip peripheral module.
2. * * * * 3. * * *
Rev.2.00 Jun. 28, 2007 Page 587 of 666 REJ09B0311-0200
Section 19 List of Registers
19.1
Register Addresses (Address Order)
Number of Bits Address
8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 H'FFB80 H'FFB81 H'FFB82 H'FFB85 H'FFB89 H'FFB8A H'FFB8C H'FFB8D H'FFB8E H'FFB90 H'FFB91 H'FFB92 H'FFB94 H'FFB95 H'FFB99 H'FFB9A H'FFB9C H'FFB9D H'FFB9E H'FFBA0 H'FFBA1 H'FFBA4 H'FFBA5 H'FFBA8 H'FFBA9 H'FFBAC H'FFBAD
Register Name
Port 1 data direction register Port 2 data direction register Port 3 data direction register Port 6 data direction register Port A data direction register Port B data direction register Port D data direction register Port E data direction register Port F data direction register Port 1 input buffer control register Port 2 input buffer control register Port 3 input buffer control register Port 5 input buffer control register Port 6 input buffer control register Port A input buffer control register Port B input buffer control register Port D input buffer control register Port E input buffer control register Port F input buffer control register Port H register Port I register Port H data register Port I data register Port H data direction register Port I data direction register Port H input buffer control register Port I input buffer control register
Abbreviation
P1DDR P2DDR P3DDR P6DDR PADDR PBDDR PDDDR PEDDR PFDDR P1ICR P2ICR P3ICR P5ICR P6ICR PAICR PBICR PDICR PEICR PFICR PORTH PORTI PHDR PIDR PHDDR PIDDR PHICR PIICR
Module
I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port
Data Width
8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8
Access Cycles (Read/Write)
2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P
Rev.2.00 Jun. 28, 2007 Page 588 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Name
Abbreviation
Number of Bits Address
8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 16 H'FFBB4 H'FFBB5 H'FFBB6 H'FFBB8 H'FFBB9 H'FFBBC H'FFBBD H'FFBC0 H'FFBC1 H'FFBC2 H'FFBC4 H'FFBC6 H'FFBC9 H'FFBCB H'FFBCC H'FFBCE
Module
I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port INTC
Data Width
8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8
Access Cycles (Read/Write)
2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/3P 2P/3P 2P/3P 2P/3P 2P/3P 2P/3P 2P/3P 2P/3P 2P/3P
Port D pull-up MOS control register PDPCR Port E pull-up MOS control register PEPCR Port F pull-up MOS control register PFPCR Port H pull-up MOS control register PHPCR Port I pull-up MOS control register Port 2 open drain control register Port F open drain control register Port function control register 0 Port function control register 1 Port function control register 2 Port function control register 4 Port function control register 6 Port function control register 9 Port function control register B Port function control register C Software standby release IRQ enable register Interrupt priority register A Interrupt priority register B Interrupt priority register C Interrupt priority register E Interrupt priority register F Interrupt priority register G Interrupt priority register H Interrupt priority register K Interrupt priority register L IRQ sense control register H IRQ sense control register L IPRA IPRB IPRC IPRE IPRF IPRG IPRH IPRK IPRL ISCRH ISCRL PIPCR P2ODR PFODR PFCR0 PFCR1 PFCR2 PFCR4 PFCR6 PFCR9 PFCRB PFCRC SSIER
16 16 16 16 16 16 16 16 16 16 16
H'FFD40 H'FFD42 H'FFD44 H'FFD48 H'FFD4A H'FFD4C H'FFD4E H'FFD54 H'FFD56 H'FFD68 H'FFD6A
INTC INTC INTC INTC INTC INTC INTC INTC INTC INTC INTC
16 16 16 16 16 16 16 16 16 16 16
2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I
Rev.2.00 Jun. 28, 2007 Page 589 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Name
DTC vector base register Bus width control register Access state control register Wait control register A Wait control register B
Abbreviation
DTCVBR ABWCR ASTCR WTCRA WTCRB
Number of Bits Address
32 16 16 16 16 16 16 16 16 8 8 16 16 H'FFD80 H'FFD84 H'FFD86 H'FFD88 H'FFD8A H'FFD8C H'FFD8E H'FFD90 H'FFD92 H'FFD94 H'FFD95 H'FFD98 H'FFD9A
Module
BSC BSC BSC BSC BSC BSC BSC BSC BSC BSC BSC BSC BSC
Data Width
16 16 16 16 16 16 16 16 16 16 16 16 16
Access Cycles (Read/Write)
2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I
Read strobe timing control register RDNCR CS assert period control register Idle control register Bus control register 1 Bus control register 2 Endian control register SRAM mode control register Burst ROM interface control register Address/data multiplexed I/O control register Mode control register System control register System clock control register Standby control register Module stop control register A Module stop control register B Module stop control register C Serial extended mode register_2 Serial mode register_4 Bit rate register_4 Serial control register_4 Transmit data register_4 Serial status register_4 Receive data register_4 Smart card mode register_4 MDCR SYSCR SCKCR SBYCR MSTPCRA MSTPCRB MSTPCRC SEMR_2 SMR_4 BRR_4 SCR_4 TDR_4 SSR_4 RDR_4 SCMR_4 MPXCR CSACR IDLCR BCR1 BCR2 ENDIANCR SRAMCR BROMCR
16
H'FFD9C
BSC
16
2I/3I
16 16 16 16 16 16 16 8 8 8 8 8 8 8 8
H'FFDC0 H'FFDC2 H'FFDC4 H'FFDC6 H'FFDC8 H'FFDCA H'FFDCC H'FFE84 H'FFE90 H'FFE91 H'FFE92 H'FFE93 H'FFE94 H'FFE95 H'FFE96
SYSTEM SYSTEM SYSTEM SYSTEM SYSTEM SYSTEM SYSTEM SCI_2 SCI_4 SCI_4 SCI_4 SCI_4 SCI_4 SCI_4 SCI_4
16 16 16 16 16 16 16 8 8 8 8 8 8 8 8
2I/3I 2I/3I 2I/3Iv 2I/3I 2I/3I 2I/3I 2I/3I 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P
Rev.2.00 Jun. 28, 2007 Page 590 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Name
Timer control register_2 Timer control register_3 Timer control/status register_2 Timer control/status register_3 Time constant register A_2 Time constant register A_3 Time constant register B_2 Time constant register B_3 Timer counter_2 Timer counter_3 Timer counter control register_2 Timer counter control register_3 Timer control register_4 Timer mode register_4 Timer I/O control register_4 Timer interrupt enable register_4 Timer status register_4 Timer counter_4 Timer general register A_4 Timer general register B_4 Timer control register_5 Timer mode register_5 Timer I/O control register_5 Timer interrupt enable register_5 Timer status register_5 Timer counter_5 Timer general register A_5 Timer general register B_5
Abbreviation
TCR_2 TCR_3 TCSR_2 TCSR_3 TCORA_2 TCORA_3 TCORB_2 TCORB_3 TCNT_2 TCNT_3 TCCR_2 TCCR_3 TCR_4 TMDR_4 TIOR_4 TIER_4 TSR_4 TCNT_4 TGRA_4 TGRB_4 TCR_5 TMDR_5 TIOR_5 TIER_5 TSR_5 TCNT_5 TGRA_5 TGRB_5
Number of Bits Address
8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 16 16 16 8 8 8 8 8 16 16 16 H'FFEC0 H'FFEC1 H'FFEC2 H'FFEC3 H'FFEC4 H'FFEC5 H'FFEC6 H'FFEC7 H'FFEC8 H'FFEC9 H'FFECA H'FFECB H'FFEE0 H'FFEE1 H'FFEE2 H'FFEE4 H'FFEE5 H'FFEE6 H'FFEE8 H'FFEEA H'FFEF0 H'FFEF1 H'FFEF2 H'FFEF4 H'FFEF5 H'FFEF6 H'FFEF8 H'FFEFA
Module
TMR_2 TMR_3 TMR_2 TMR_3 TMR_2 TMR_3 TMR_2 TMR_3 TMR_2 TMR_3 TMR_2 TMR_3 TPU_4 TPU_4 TPU_4 TPU_4 TPU_4 TPU_4 TPU_4 TPU_4 TPU_5 TPU_5 TPU_5 TPU_5 TPU_5 TPU_5 TPU_5 TPU_5
Data Width
16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16
Access Cycles (Read/Write)
2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P
Rev.2.00 Jun. 28, 2007 Page 591 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Name
DTC enable register A DTC enable register B DTC enable register C DTC enable register D DTC enable register E DTC enable register F DTC enable register G DTC enable register H DTC control register Interrupt control register CPU priority control register IRQ enable register IRQ status register Port 1 register Port 2 register Port 3 register Port 5 register Port 6 register Port A register Port B register Port D register Port E register Port F register Port 1 data register Port 2 data register Port 3 data register Port 6 data register
Abbreviation
DTCERA DTCERB DTCERC DTCERD DTCERE DTCERF DTCERG DTCERH DTCCR INTCR CPUPCR IER ISR PORT1 PORT2 PORT3 PORT5 PORT6 PORTA PORTB PORTD PORTE PORTF P1DR P2DR P3DR P6DR
Number of Bits Address
16 16 16 16 16 16 16 16 8 8 8 16 16 8 8 8 8 8 8 8 8 8 8 8 8 8 8 H'FFF20 H'FFF22 H'FFF24 H'FFF26 H'FFF28 H'FFF2A H'FFF2C H'FFF2E H'FFF30 H'FFF32 H'FFF33 H'FFF34 H'FFF36 H'FFF40 H'FFF41 H'FFF42 H'FFF44 H'FFF45 H'FFF49 H'FFF4A H'FFF4C H'FFF4D H'FFF4E H'FFF50 H'FFF51 H'FFF52 H'FFF55
Module
INTC INTC INTC INTC INTC INTC INTC INTC INTC INTC INTC INTC INTC I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port I/O port
Data Width
16 16 16 16 16 16 16 16 16 16 16 16 16 8 8 8 8 8 8 8 8 8 8 8 8 8 8
Access Cycles (Read/Write)
2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2I/3I 2P/ 2P/ 2P/ 2P/ 2P/ 2P/ 2P/ 2P/ 2P/ 2P/ 2P/2P 2P/2P 2P/2P 2P/2P
Rev.2.00 Jun. 28, 2007 Page 592 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Name
Port A data register Port B data register Port D data register Port E data register Port F data register Serial mode register_2 Bit rate register_2 Serial control register_2 Transmit data register_2 Serial status register_2 Receive data register_2 Smart card mode register_2 D/A data register 0 D/A data register 1 D/A control register 01 PPG output control register PPG output mode register Next data enable register H Next data enable register L Output data register H Output data register L Next data register H* Next data register L* Next data register H* Next data register L*
Abbreviation
PADR PBDR PDDR PEDR PFDR SMR_2 BRR_2 SCR_2 TDR_2 SSR_2 RDR_2 SCMR_2 DADR0 DADR1 DACR01 PCR PMR NDERH NDERL PODRH PODRL NDRH NDRL NDRH NDRL
Number of Bits Address
8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 H'FFF59 H'FFF5A H'FFF5C H'FFF5D H'FFF5E H'FFF60 H'FFF61 H'FFF62 H'FFF63 H'FFF64 H'FFF65 H'FFF66 H'FFF68 H'FFF69 H'FFF6A H'FFF76 H'FFF77 H'FFF78 H'FFF79 H'FFF7A H'FFF7B H'FFF7C H'FFF7D H'FFF7E H'FFF7F
Module
I/O port I/O port I/O port I/O port I/O port SCI_2 SCI_2 SCI_2 SCI_2 SCI_2 SCI_2 SCI_2 D/A D/A D/A PPG PPG PPG PPG PPG PPG PPG PPG PPG PPG
Data Width
8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8
Access Cycles (Read/Write)
2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P
Rev.2.00 Jun. 28, 2007 Page 593 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Name
Serial mode register_0 Bit rate register_0 Serial control register_0 Transmit data register_0 Serial status register_0 Receive data register_0 Smart card mode register_0 Serial mode register_1 Bit rate register_1 Serial control register_1 Transmit data register_1 Serial status register_1 Receive data register_1 Smart card mode register_1 A/D data register A A/D data register B A/D data register C A/D data register D A/D data register E A/D data register F A/D data register G A/D data register H A/D control/status register A/D control register Timer control/status register Timer counter Reset control/status register Timer control register_0 Timer control register_1 Timer control/status register_0
Abbreviation
SMR_0 BRR_0 SCR_0 TDR_0 SSR_0 RDR_0 SCMR_0 SMR_1 BRR_1 SCR_1 TDR_1 SSR_1 RDR_1 SCMR_1 ADDRA ADDRB ADDRC ADDRD ADDRE ADDRF ADDRG ADDRH ADCSR ADCR TCSR TCNT RSTCSR TCR_0 TCR_1 TCSR_0
Number of Bits Address
8 8 8 8 8 8 8 8 8 8 8 8 8 8 16 16 16 16 16 16 16 16 8 8 8 8 8 8 8 8 H'FFF80 H'FFF81 H'FFF82 H'FFF83 H'FFF84 H'FFF85 H'FFF86 H'FFF88 H'FFF89 H'FFF8A H'FFF8B H'FFF8C H'FFF8D H'FFF8E H'FFF90 H'FFF92 H'FFF94 H'FFF96 H'FFF98 H'FFF9A H'FFF9C H'FFF9E H'FFFA0 H'FFFA1 H'FFFA4 H'FFFA5 H'FFFA7 H'FFFB0 H'FFFB1 H'FFFB2
Module
SCI_0 SCI_0 SCI_0 SCI_0 SCI_0 SCI_0 SCI_0 SCI_1 SCI_1 SCI_1 SCI_1 SCI_1 SCI_1 SCI_1 A/D A/D A/D A/D A/D A/D A/D A/D A/D A/D WDT WDT WDT TMR_0 TMR_1 TMR_0
Data Width
8 8 8 8 8 8 8 8 8 8 8 8 8 8 16 16 16 16 16 16 16 16 16 16
Access Cycles (Read/Write)
2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/3P 2P/3P 2P/3P
16 16 16
2P/2P 2P/2P 2P/2P
Rev.2.00 Jun. 28, 2007 Page 594 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Name
Timer control/status register_1 Time constant register A_0 Time constant register A_1 Time constant register B_0 Time constant register B_1 Timer counter_0 Timer counter_1 Timer counter control register_0 Timer counter control register_1 Timer start register Timer synchronous register Timer control register_0 Timer mode register_0 Timer I/O control register H_0 Timer I/O control register L_0 Timer interrupt enable register_0 Timer status register_0 Timer counter_0 Timer general register A_0 Timer general register B_0 Timer general register C_0 Timer general register D_0 Timer control register_1 Timer mode register_1 Timer I/O control register_1 Timer interrupt enable register_1 Timer status register_1 Timer counter_1 Timer general register A_1 Timer general register B_1
Abbreviation
TCSR_1 TCORA_0 TCORA_1 TCORB_0 TCORB_1 TCNT_0 TCNT_1 TCCR_0 TCCR_1 TSTR TSYR TCR_0 TMDR_0 TIORH_0 TIORL_0 TIER_0 TSR_0 TCNT_0 TGRA_0 TGRB_0 TGRC_0 TGRD_0 TCR_1 TMDR_1 TIOR_1 TIER_1 TSR_1 TCNT_1 TGRA_1 TGRB_1
Number of Bits Address
8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 16 16 16 16 16 8 8 8 8 8 16 16 16 H'FFFB3 H'FFFB4 H'FFFB5 H'FFFB6 H'FFFB7 H'FFFB8 H'FFFB9 H'FFFBA H'FFFBB H'FFFBC H'FFFBD H'FFFC0 H'FFFC1 H'FFFC2 H'FFFC3 H'FFFC4 H'FFFC5 H'FFFC6 H'FFFC8 H'FFFCA H'FFFCC H'FFFCE H'FFFD0 H'FFFD1 H'FFFD2 H'FFFD4 H'FFFD5 H'FFFD6 H'FFFD8 H'FFFDA
Module
TMR_1 TMR_0 TMR_1 TMR_0 TMR_1 TMR_0 TMR_1 TMR_0 TMR_1 TPU TPU TPU_0 TPU_0 TPU_0 TPU_0 TPU_0 TPU_0 TPU_0 TPU_0 TPU_0 TPU_0 TPU_0 TPU_1 TPU_1 TPU_1 TPU_1 TPU_1 TPU_1 TPU_1 TPU_1
Data Width
16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16
Access Cycles (Read/Write)
2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P
Rev.2.00 Jun. 28, 2007 Page 595 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Name
Timer control register_2 Timer mode register_2 Timer I/O control register_2 Timer interrupt enable register_2 Timer status register_2 Timer counter_2 Timer general register A_2 Timer general register B_2 Timer control register_3 Timer mode register_3 Timer I/O control register H_3 Timer I/O control register L_3 Timer interrupt enable register_3 Timer status register_3 Timer counter_3 Timer general register A_3 Timer general register B_3 Timer general register C_3 Timer general register D_3
Abbreviation
TCR_2 TMDR_2 TIOR_2 TIER_2 TSR_2 TCNT_2 TGRA_2 TGRB_2 TCR_3 TMDR_3 TIORH_3 TIORL_3 TIER_3 TSR_3 TCNT_3 TGRA_3 TGRB_3 TGRC_3 TGRD_3
Number of Bits Address
8 8 8 8 8 16 16 16 8 8 8 8 8 8 16 16 16 16 16 H'FFFE0 H'FFFE1 H'FFFE2 H'FFFE4 H'FFFE5 H'FFFE6 H'FFFE8 H'FFFEA H'FFFF0 H'FFFF1 H'FFFF2 H'FFFF3 H'FFFF4 H'FFFF5 H'FFFF6 H'FFFF8 H'FFFFA H'FFFFC H'FFFFE
Module
TPU_2 TPU_2 TPU_2 TPU_2 TPU_2 TPU_2 TPU_2 TPU_2 TPU_3 TPU_3 TPU_3 TPU_3 TPU_3 TPU_3 TPU_3 TPU_3 TPU_3 TPU_3 TPU_3
Data Width
16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16
Access Cycles (Read/Write)
2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P 2P/2P
Note: *
When the same output trigger is specified for pulse output groups 2 and 3 by the PCR setting, the NDRH address is H'FFF7C. When different output triggers are specified, the NDRH addresses for pulse output groups 2 and 3 are H'FFF7E and H'FFF7C, respectively. Similarly, when the same output trigger is specified for pulse output groups 0 and 1 by the PCR setting, the NDRL address is H'FFF7D. When different output triggers are specified, the NDRL addresses for pulse output groups 0 and 1 are H'FFF7F and H'FFF7D, respectively.
Rev.2.00 Jun. 28, 2007 Page 596 of 666 REJ09B0311-0200
Section 19 List of Registers
19.2
Register Bits
Register addresses and bit names of the on-chip peripheral modules are described below. Each line covers eight bits, and 16-bit and 32-bit registers are shown as 2 or 4 lines, respectively.
Register Abbreviation P1DDR P2DDR P3DDR P6DDR PADDR PBDDR PDDDR PEDDR PFDDR P1ICR P2ICR P3ICR P5ICR P6ICR PAICR PBICR PDICR PEICR PFICR PORTH PORTI PHDR PIDR PHDDR PIDDR PHICR PIICR Bit Bit Bit Bit Bit Bit Bit Bit 24/16/8/0 P10DDR P20DDR P30DDR P60DDR PA0DDR PB0DDR PD0DDR PE0DDR PF0DDR P10ICR P20ICR P30ICR P50ICR P60ICR PA0ICR PB0ICR PD0ICR PE0ICR PF0ICR PH0 PI0 PH0DR PI0DR PH0DDR PI0DDR PH0ICR PI0ICR Module I/O port
31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2 25/17/9/1 P17DDR P27DDR P37DDR PA7DDR PD7DDR PE7DDR PF7DDR P17ICR P27ICR P37ICR P57ICR PA7ICR PD7ICR PE7ICR PF7ICR PH7 PI7 PH7DR PI7DR PH7DDR PI7DDR PH7ICR PI7ICR P16DDR P26DDR P36DDR PA6DDR PD6DDR PE6DDR PF6DDR P16ICR P26ICR P36ICR P56ICR PA6ICR PD6ICR PE6ICR PF6ICR PH6 PI6 PH6DR PI6DR PH6DDR PI6DDR PH6ICR PI6ICR P15DDR P25DDR P35DDR P65DDR PA5DDR PD5DDR PE5DDR PF5DDR P15ICR P25ICR P35ICR P55ICR P65ICR PA5ICR PD5ICR PE5ICR PF5ICR PH5 PI5 PH5DR PI5DR PH5DDR PI5DDR PH5ICR PI5ICR P14DDR P24DDR P34DDR P64DDR PA4DDR PD4DDR PE4DDR PF4DDR P14ICR P24ICR P34ICR P54ICR P64ICR PA4ICR PD4ICR PE4ICR PF4ICR PH4 PI4 PH4DR PI4DR PH4DDR PI4DDR PH4ICR PI4ICR P13DDR P23DDR P33DDR P63DDR PA3DDR PB3DDR PD3DDR PE3DDR PF3DDR P13ICR P23ICR P33ICR P53ICR P63ICR PA3ICR PB3ICR PD3ICR PE3ICR PF3ICR PH3 PI3 PH3DR PI3DR PH3DDR PI3DDR PH3ICR PI3ICR P12DDR P22DDR P32DDR P62DDR PA2DDR PB2DDR PD2DDR PE2DDR PF2DDR P12ICR P22ICR P32ICR P52ICR P62ICR PA2ICR PB2ICR PD2ICR PE2ICR PF2ICR PH2 PI2 PH2DR PI2DR PH2DDR PI2DDR PH2ICR PI2ICR P11DDR P21DDR P31DDR P61DDR PA1DDR PB1DDR PD1DDR PE1DDR PF1DDR P11ICR P21ICR P31ICR P51ICR P61ICR PA1ICR PB1ICR PD1ICR PE1ICR PF1ICR PH1 PI1 PH1DR PI1DR PH1DDR PI1DDR PH1ICR PI1ICR
Rev.2.00 Jun. 28, 2007 Page 597 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Abbreviation PDPCR PEPCR PFPCR PHPCR PIPCR P2ODR PFODR PFCR0 PFCR1 PFCR2 PFCR4 PFCR6 PFCR9 PFCRB PFCRC SSIER
Bit
Bit
Bit
Bit
Bit
Bit
Bit
Bit 24/16/8/0 PD0PCR PE0PCR PF0PCR PH0PCR PI0PCR P20ODR PF0ODR CS0E CS4SB Module I/O port
31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2 25/17/9/1 PD7PCR PE7PCR PF7PCR PH7PCR PI7PCR P27ODR PF7ODR CS7E CS7SA A23E TPUMS5 ITS7 SSI7 PD6PCR PE6PCR PF6PCR PH6PCR PI6PCR P26ODR PF6ODR CS6E CS7SB CS2S A22E LHWROE TPUMS4 ITS6 SSI6 IPRA14 IPRA6 IPRB14 IPRB6 IPRC14 IPRC6 IPRF6 IPRG14 IPRG6 IPRH14 IPRH6 IPRK6 IPRL14 IPRL6 PD5PCR PE6PCR PF5PCR PH5PCR PI5PCR P25ODR PF5ODR CS5E CS6SA BSS A21E PD4PCR PE4PCR PF4PCR PH4PCR PI4PCR P24ODR PF4ODR CS4E CS6SB BSE PD3PCR PE3PCR PF3PCR PH3PCR PI3PCR P23ODR PF3ODR CS3E CS5SA TCLKS PD2PCR PE2PCR PF2PCR PH2PCR PI2PCR P22ODR PF2ODR CS2E CS5SB RDWRE TPUMS1 ITS10 ITS2 SSI10 SSI2 IPRA10 IPRA2 IPRB10 IPRB2 IPRC10 IPRC2 IPRE10 IPRF10 IPRF2 IPRG10 IPRG2 IPRH10 IPRH2 IPRK2 PD1PCR PE1PCR PF1PCR PH1PCR PI1PCR P21ODR PF1ODR CS1E CS4SA ASOE
TPUMS3A TPUMS3B TPUMS2 ITS5 SSI5 IPRA13 IPRA5 IPRB13 IPRB5 IPRC13 IPRC5 IPRF5 IPRG13 IPRG5 IPRH13 IPRH5 IPRK5 IPRL13 IPRL5 ITS4 SSI4 IPRA12 IPRA4 IPRB12 IPRB4 IPRC12 IPRC4 IPRF4 IPRG12 IPRG4 IPRH12 IPRH4 IPRK4 IPRL12 IPRL4 ITS11 ITS3 SSI11 SSI3
TPUMS0A TPUMS0B ITS9 ITS1 SSI9 SSI1 IPRA9 IPRA1 IPRB9 IPRB1 IPRC9 IPRC1 IPRE9 IPRF9 IPRF1 IPRG9 IPRG1 IPRH9 IPRH1 IPRK1 ITS8 ITS0 SSI8 SSI0 IPRA8 IPRA0 IPRB8 IPRB0 IPRC8 IPRC0 IPRE8 IPRF8 IPRF0 IPRG8 IPRG0 IPRH8 IPRH0 IPRK0 INTC
IPRA

IPRB

IPRC

IPRE

IPRF

IPRG

IPRH

IPRK

IPRL

Rev.2.00 Jun. 28, 2007 Page 598 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Abbreviation ISCRH
Bit
Bit
Bit
Bit
Bit
Bit
Bit
Bit 24/16/8/0 IRQ8SF IRQ4SF IRQ0SF BSC Module
31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2 25/17/9/1 IRQ11SR IRQ11SF IRQ7SF IRQ3SF IRQ10SR IRQ6SR IRQ2SR IRQ10SF IRQ6SF IRQ2SF IRQ9SR IRQ5SR IRQ1SR IRQ9SF IRQ5SF IRQ1SF IRQ8SR IRQ4SR IRQ0SR
ISCRL
IRQ7SR IRQ3SR
DTCVBR
ABWCR
ABWH7 ABWL7
ABWH6 ABWL6 AST6 W72 W52 W32 W12 RDN6 CSXH6 CSXT6 IDLS2 IDLSEL6 BREQOE LE6 BCSEL6 BSTS02 BSTS12 MPXE6
ABWH5 ABWL5 AST5 W71 W51 W31 W11 RDN5 CSXH5 CSXT5 IDLS1 IDLSEL5 LE5 BCSEL5 BSTS01 BSTS11 MPXE5
ABWH4 ABWL4 AST4 W70 W50 W30 W10 RDN4 CSXH4 CSXT4 IDLS0 IDLSEL4 IBCCS LE4 BCSEL4 BSTS00 BSTS10 MPXE4
ABWH3 ABWL3 AST3 RDN3 CSXH3 CSXT3 IDLCB1 IDLSEL3 LE3 BCSEL3 MPXE3
ABWH2 ABWL2 AST2 W62 W42 W22 W02 RDN2 CSXH2 CSXT2 IDLCB0 IDLSEL2 LE2 BCSEL2
ABWH1 ABWL1 AST1 W61 W41 W21 W01 RDN1 CSXH1 CSXT1 IDLCA1 IDLSEL1 WDBE BCSEL1 BSWD01 BSWD11
ABWH0 ABWL0 AST0 W60 W40 W20 W00 RDN0 CSXH0 CSXT0 IDLCA0 IDLSEL0 WAITE PWDBE BCSEL0 BSWD00 BSWD10 ADDEX
ASTCR
AST7
WTCRA

WTCRB

RDNCR
RDN7
CSACR
CSXH7 CSXT7
IDLCR
IDLSEL7
BCR1
BRLE
BCR2 ENDIANCR SRAMCR
LE7 BCSEL7
BROMCR
BSRM0 BSRM1
MPXCR
MPXE7
Rev.2.00 Jun. 28, 2007 Page 599 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Abbreviation MDCR
Bit
Bit
Bit
Bit
Bit
Bit
Bit
Bit 24/16/8/0 MDS0 RAME ICK0 BCK0 STS0 MSTPA8 MSTPA0 MSTPB8 MSTPB0 MSTPC8 MSTPC0 ACS0 CKS0 SCI_2 SCI_4 Module SYSTEM
31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2 25/17/9/1 PCK2 OPE MACS PCK1 PCK0 STS4 MDS2 MDS1 EXPE DTCMD ICK1 BCK1 STS1
SYSCR

FETCHMD STS3 ICK2 BCK2 STS2
SCKCR
PSTOP1
SBYCR
SSBY SLPIE
MSTPCRA
ACSE MSTPA7
MSTPA14 MSTPA13 MSTPA12 MSTPA11 MSTPA10 MSTPA9 MSTPA6 MSTPA5 MSTPA4 MSTPA3 MSTPA2 MSTPA1
MSTPCRB
MSTPB15 MSTPB14 MSTPB13 MSTPB12 MSTPB11 MSTPB10 MSTPB9 MSTPB7 MSTPB6 MSTPB5 MSTPB4 MSTPB3 MSTPB2 MSTPB1
MSTPCRC
MSTPC15 MSTPC14 MSTPC13 MSTPC12 MSTPC11 MSTPC10 MSTPC9 MSTPC7 MSTPC5 MSTPC5 MSTPC4 O/E (O/E) MSTPC3 ABCS STOP (BCP1) MSTPC2 ACS2 MP (BCP0) MSTPC1 ACS1 CKS1
SEMR_2 SMR_4*1 BRR_4 SCR_4*1 TDR_4 SSR_4*1 RDR_4 SCMR_4 TCR_2 TCR_3 TCSR_2 TCSR_3 TCORA_2 TCORA_3 TCORB_2 TCORB_3 TCNT_2 TCNT_3 TCCR_2 TCCR_3
C/A (GM)
CHR (BLK) PE (PE)
TIE
RIE
TE
RE
MPIE
TEIE
CKE1
CKE0
TDRE
RDRF
ORER
FER (ERS) PER
TEND
MPB
MPBT
CMIEB CMIEB CMFB CMFB
CMIEA CMIEA CMFA CMFA
OVIE OVIE OVF OVF
CCLR1 CCLR1 ADTE
SDIR CCLR0 CCLR0 OS3 OS3
SINV CKS2 CKS2 OS2 OS2
CKS1 CKS1 OS1 OS1
SMIF CKS0 CKS0 OS0 OS0 TMR_2 TMR_3 TMR_2 TMR_3 TMR_2 TMR_3 TMR_2 TMR_3 TMR_2 TMR_3




TMRIS TMRIS

ICKS1 ICKS1
ICKS0 ICKS0
TMR_2 TMR_3
Rev.2.00 Jun. 28, 2007 Page 600 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Abbreviation TCR_4 TMDR_4 TIOR_4 TIER_4 TSR_4 TCNT_4
Bit
Bit
Bit
Bit
Bit
Bit
Bit
Bit 24/16/8/0 TPSC0 MD0 IOA0 TGIEA TGFA Module TPU_4
31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2 25/17/9/1 IOB3 TTGE TCFD CCLR1 IOB2 CCLR0 IOB1 TCIEU TCFU CKEG1 IOB0 TCIEV TCFV CKEG0 IOA3 TPSC2 MD2 IOA2 TPSC1 MD1 IOA1 TGIEB TGFB
TGRA_4
TGRB_4
TCR_5 TMDR_5 TIOR_5 TIER_5 TSR_5 TCNT_5
IOB3 TTGE TCFD
CCLR1 IOB2
CCLR0 IOB1 TCIEU TCFU
CKEG1 IOB0 TCIEV TCFV
CKEG0 IOA3
TPSC2 MD2 IOA2
TPSC1 MD1 IOA1 TGIEB TGFB
TPSC0 MD0 IOA0 TGIEA TGFA
TPU_5
TGRA_5
TGRB_5
DTCERA
DTCE15 DTCE7
DTCE14 DTCE6 DTCE14 DTCE6 DTCE14 DTCE6 DTCE14 DTCE6 DTCE14 DTCE6 DTCE14 DTCE6 DTCE14 DTCE6
DTCE13 DTCE5 DTCE13 DTCE5 DTCE13 DTCE5 DTCE13 DTCE5 DTCE13 DTCE5 DTCE13 DTCE5 DTCE13 DTCE5
DTCE12 DTCE4 DTCE12 DTCE4 DTCE12 DTCE4 DTCE12 DTCE4 DTCE12 DTCE4 DTCE12 DTCE4 DTCE12 DTCE4
DTCE11 DTCE3 DTCE11 DTCE3 DTCE11 DTCE3 DTCE11 DTCE3 DTCE11 DTCE3 DTCE11 DTCE3 DTCE11 DTCE3
DTCE10 DTCE2 DTCE10 DTCE2 DTCE10 DTCE2 DTCE10 DTCE2 DTCE10 DTCE2 DTCE10 DTCE2 DTCE10 DTCE2
DTCE9 DTCE1 DTCE9 DTCE1 DTCE9 DTCE1 DTCE9 DTCE1 DTCE9 DTCE1 DTCE9 DTCE1 DTCE9 DTCE1
DTCE8 DTCE0 DTCE8 DTCE0 DTCE8 DTCE0 DTCE8 DTCE0 DTCE8 DTCE0 DTCE8 DTCE0 DTCE8 DTCE0
INTC
DTCERB
DTCE15 DTCE7
DTCERC
DTCE15 DTCE7
DTCERD
DTCE15 DTCE7
DTCERE
DTCE15 DTCE7
DTCERF
DTCE15 DTCE7
DTCERG
DTCE15 DTCE7
Rev.2.00 Jun. 28, 2007 Page 601 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Abbreviation DTCERH
Bit
Bit
Bit
Bit
Bit
Bit
Bit
Bit 24/16/8/0 DTCE8 DTCE0 ERR CPUP0 IRQ8E IRQ0E IRQ8F IRQ0F P10 P20 P30 P50 P60 PA0 PB0 PD0 PE0 PF0 P10DR P20DR P30DR P60DR PA0DR PA0DR PD0DR PE0DR PF0DR CKS0 SCI_2 I/O port Module INTC
31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2 25/17/9/1 DTCE15 DTCE7 DTCE14 DTCE6 DTCP2 IRQ6E IRQ6F P16 P26 P36 P56 PA6 PD6 PE6 PF6 P16DR P26DR P36DR PA6DR PD6DR PE6DR PF6DR DTCE13 DTCE5 INTM1 DTCP1 IRQ5E IRQ5F P15 P25 P35 P55 P65 PA5 PD5 PE5 PF5 P15DR P25DR P35DR P65DR PA5DR PD5DR PE5DR PF5DR DTCE12 DTCE4 RRS INTM0 DTCP0 IRQ4E IRQ4F P14 P24 P34 P54 P64 PA4 PD4 PE4 PF4 P14DR P24DR P34DR P64DR PA4DR PD4DR PE4DR PF4DR O/E (O/E) DTCE11 DTCE3 RCHNE NMIEG IPSETE IRQ11E IRQ3E IRQ11F IRQ3F P13 P23 P33 P53 P63 PA3 PB3 PD3 PE3 PF3 P13DR P23DR P33DR P63DR PA3DR PB3DR PD3DR PE3DR PF3DR STOP (BCP1) DTCE10 DTCE2 CPUP2 IRQ10E IRQ2E IRQ10F IRQ2F P12 P22 P32 P52 P62 PA2 PB2 PD2 PE2 PF2 P12DR P22DR P32DR P62DR PA2DR PB2DR PD2DR PE2DR PF2DR MP (BCP0) DTCE9 DTCE1 CPUP1 IRQ9E IRQ1E IRQ9F IRQ1F P11 P21 P31 P51 P61 PA1 PB1 PD1 PE1 PF1 P11DR P21DR P31DR P61DR PA1DR PB1DR PD1DR PE1DR PF1DR CKS1
DTCCR INTCR CPUPCR IER
CPUPCE IRQ7E
ISR
IRQ7F
PORT1 PORT2 PORT3 PORT5 PORT6 PORTA PORTB PORTD PORTE PORTF P1DR P2DR P3DR P6DR PADR PBDR PDDR PEDR PFDR SMR_2*1 BRR_2 SCR_2*1 TDR_2 SSR_2*1 RDR_2 SCMR_2
P17 P27 P37 P57 PA7 PD7 PE7 PF7 P17DR P27DR P37DR PA7DR PD7DR PE7DR PF7DR C/A (GM)
CHR (BLK) PE (PE)
TIE
RIE
TE
RE
MPIE
TEIE
CKE1
CKE0
TDRE
RDRF
ORER
FER (ERS) PER
TEND
MPB
MPBT

SDIR
SINV
SMIF
Rev.2.00 Jun. 28, 2007 Page 602 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Abbreviation DADR0 DADR1 DACR01 PCR PMR NDERH NDERL PODRH PODRL NDRH*
2
Bit
Bit
Bit
Bit
Bit
Bit
Bit
Bit 24/16/8/0 Module D/A
31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2 25/17/9/1
DAOE1 G3CMS1 G3INV NDER15 NDER7 POD15 POD7 NDR15 NDR7 C/A (GM)
DAOE0 G3CMS0 G2INV NDER14 NDER6 POD14 POD6 NDR14 NDR6
DAE G2CMS1 G1INV NDER13 NDER5 POD13 POD5 NDR13 NDR5
G2CMS0 G0INV NDER12 NDER4 POD12 POD4 NDR12 NDR4 O/E (O/E)
G1CMS1 G3NOV NDER11 NDER3 POD11 POD3 NDR11 NDR3 NDR11 NDR3 STOP (BCP1)
G1CMS0 G2NOV NDER10 NDER2 POD10 POD2 NDR10 NDR2 NDR10 NDR2 MP (BCP0)
G0CMS1 G1NOV NDER9 NDER1 POD9 POD1 NDR9 NDR1 NDR9 NDR1 CKS1
G0CMS0 G0NOV NDER8 NDER0 POD8 POD0 NDR8 NDR0 NDR8 NDR0 CKS0 SCI_0 PPG
NDRL*2 NDRH*2 NDRL*2 SMR_0*1 BRR_0 SCR_0*1 TDR_0 SSR_0*1 RDR_0 SCMR_0 SMR_1*1 BRR_1 SCR_1*1 TDR_1 SSR_1*1 RDR_1 SCMR_1 ADDRA
CHR (BLK) PE (PE)
TIE
RIE
TE
RE
MPIE
TEIE
CKE1
CKE0
TDRE
RDRF
ORER
FER (ERS) PER
TEND
MPB
MPBT
C/A (GM)
O/E (O/E)
SDIR STOP (BCP1)
SINV MP (BCP0)
CKS1
SMIF CKS0 SCI_1
CHR (BLK) PE (PE)
TIE
RIE
TE
RE
MPIE
TEIE
CKE1
CKE0
TDRE
RDRF
ORER
FER (ERS) PER
TEND
MPB
MPBT

SDIR
SINV
SMIF A/D
ADDRB
ADDRC
Rev.2.00 Jun. 28, 2007 Page 603 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Abbreviation ADDRD
Bit
Bit
Bit
Bit
Bit
Bit
Bit
Bit 24/16/8/0 Module A/D
31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2 25/17/9/1
ADDRE
ADDRF
ADDRG
ADDRH
ADCSR ADCR TCSR TCNT RSTCSR TCR_0 TCR_1 TCSR_0 TCSR_1 TCORA_0 TCORA_1 TCORB_0 TCORB_1 TCNT_0 TCNT_1 TCCR_0 TCCR_1 TSTR TSYR TCR_0 TMDR_0 TIORH_0 TIORL_0 TIER_0 TSR_0
ADF TRGS1 OVF
ADIE TRGS0 WT/IT
ADST SCANE TME
SCANS
CH3 CKS1
CH2 CKS0 CKS2
CH1 CKS1
CH0 CKS0 WDT
WOVF CMIEB CMIEB CMFB CMFB
RSTE CMIEA CMIEA CMFA CMFA
OVIE OVIE OVF OVF
CCLR1 CCLR1 ADTE
CCLR0 CCLR0 OS3 OS3
CKS2 CKS2 OS2 OS2
CKS1 CKS1 OS1 OS1
CKS0 CKS0 OS0 OS0 TMR_0 TMR_1 TMR_0 TMR_1 TMR_0 TMR_1 TMR_0 TMR_1 TMR_0 TMR_1
CCLR2 IOB3 IOD3 TTGE TCFD
CCLR1 IOB2 IOD2
CST5 SYNC5 CCLR0 BFB IOB1 IOD1 TCIEU
CST4 SYNC4 CKEG1 BFA IOB0 IOD0 TCIEV TCFV
TMRIS TMRIS CST3 SYNC3 CKEG0 IOA3 IOC3 TGIED TGFD
CST2 SYNC2 TPSC2 MD2 IOA2 IOC2 TGIEC TGFC
ICKS1 ICKS1 CST1 SYNC1 TPSC1 MD1 IOA1 IOC1 TGIEB TGFB
ICKS0 ICKS0 CST0 SYNC0 TPSC0 MD0 IOA0 IOC0 TGIEA TGFA
TMR_0 TMR_1 TPU
TPU_0
Rev.2.00 Jun. 28, 2007 Page 604 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Abbreviation TCNT_0
Bit
Bit
Bit
Bit
Bit
Bit
Bit
Bit 24/16/8/0 Module TPU_0
31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2 25/17/9/1
TGRA_0
TGRB_0
TGRC_0
TGRD_0
TCR_1 TMDR_1 TIOR_1 TIER_1 TSR_1 TCNT_1
IOB3 TTGE TCFD
CCLR1 IOB2
CCLR0 IOB1 TCIEU TCFU
CKEG1 IOB0 TCIEV TGFV
CKEG0 IOA3 TGFD
TPSC2 MD2 IOA2
TPSC1 MD1 IOA1 TGIEB TGFB
TPSC0 MD0 IOA0 TGIEA TGFA
TPU_1
TGRA_1
TGRB_1
TCR_2 TMDR_2 TIOR_2 TIER_2 TSR_2 TCNT_2
IOB3 TTGE TCFD
CCLR1 IOB2
CCLR0 IOB1 TCIEU TCFU
CKEG1 IOB0 TCIEV TCFV
CKEG0 IOA3
TPSC2 MD2 IOA2
TPSC1 MD1 IOA1 TGIEB TGFB
TPSC0 MD0 IOA0 TGIEA TGFA
TPU_2
TGRA_2
TGRB_2
Rev.2.00 Jun. 28, 2007 Page 605 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Abbreviation TCR_3 TMDR_3 TIORH_3 TIORL_3 TIER_3 TSR_3 TCNT_3
Bit
Bit
Bit
Bit
Bit
Bit
Bit
Bit 24/16/8/0 TPSC0 MD0 IOA0 IOC0 TGIEA TGFA Module TPU_3
31/23/15/7 30/22/14/6 29/21/13/5 28/20/12/4 27/19/11/3 26/18/10/2 25/17/9/1 CCLR2 IOB3 IOD3 TTGE TCFD CCLR1 IOB2 IOD2 CCLR0 BFB IOB1 IOD1 TCIEU CKEG1 BFA IOB0 IOD0 TCIEV TCFV CKEG0 IOA3 IOC3 TGIED TGFD TPSC2 MD2 IOA2 IOC2 TGIEC TGFC TPSC1 MD1 IOA1 IOC1 TGIEB TGFB
TGRA_3
TGRB_3
TGRC_3
TGRD_3
Notes: 1. Parts of the bit functions differ in normal mode and the smart card interface. 2. When the same output trigger is specified for pulse output groups 2 and 3 by the PCR setting, the NDRH address is H'FFF7C. When different output triggers are specified, the NDRH addresses for pulse output groups 2 and 3 are H'FFF7E and H'FFF7C, respectively. Similarly, when the same output trigger is specified for pulse output groups 0 and 1 by the PCR setting, the NDRL address is H'FFF7D. When different output triggers are specified, the NDRL addresses for pulse output groups 0 and 1 are H'FFF7F and H'FFF7D, respectively.
Rev.2.00 Jun. 28, 2007 Page 606 of 666 REJ09B0311-0200
Section 19 List of Registers
19.3
Register States in Each Operating Mode
Module Sleep Stop State Mode All-ModuleClock-Stop Mode Software Standby Mode Hardware Standby Mode Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Register Abbreviation P1DDR P2DDR P3DDR P6DDR PADDR PBDDR PDDDR PEDDR PFDDR P1ICR P2ICR P3ICR P5ICR P6ICR PAICR PBICR PDICR PEICR PFICR PORTH PORTI PHDR PIDR PHDDR PIDDR PHICR PIICR
Reset Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Module I/O port
Rev.2.00 Jun. 28, 2007 Page 607 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Abbreviation PDPCR PEPCR PFPCR PHPCR PIPCR P2ODR PFODR PFCR0 PFCR1 PFCR2 PFCR4 PFCR6 PFCR9 PFCRB PFCRC SSIER IPRA IPRB IPRC IPRE IPRF IPRG IPRH IPRK IPRL ISCRH ISCRL
Reset Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Module Sleep Stop State Mode
All-ModuleClock-Stop Mode
Software Standby Mode
Hardware Standby Mode Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Module I/O port
INTC
Rev.2.00 Jun. 28, 2007 Page 608 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Abbreviation DTCVBR ABWCR ASTCR WTCRA WTCRB RDNCR CSACR IDLCR BCR1 BCR2 ENDIANCR SRAMCR BROMCR MPXCR MDCR SYSCR SCKCR SBYCR MSTPCRA MSTPCRB MSTPCRC SEMR_2 SMR_4 BRR_4 SCR_4 TDR_4 SSR_4 RDR_4 SCMR_4
Reset Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Module Sleep Stop State Mode Initialized Initialized Initialized
All-ModuleClock-Stop Mode Initialized Initialized Initialized
Software Standby Mode Initialized Initialized Initialized
Hardware Standby Mode Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Module BSC
SYSTEM
SCI_2 SCI_4
Rev.2.00 Jun. 28, 2007 Page 609 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Abbreviation TCR_2 TCR_3 TCSR_2 TCSR_3 TCORA_2 TCORA_3 TCORB_2 TCORB_3 TCNT_2 TCNT_3 TCCR_2 TCCR_3 TCR_4 TMDR_4 TIOR_4 TIER_4 TSR_4 TCNT_4 TGRA_4 TGRB_4 TCR_5 TMDR_5 TIOR_5 TIER_5 TSR_5 TCNT_5 TGRA_5 TGRB_5
Reset Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Module Sleep Stop State Mode
All-ModuleClock-Stop Mode
Software Standby Mode
Hardware Standby Mode Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Module TMR_2 TMR_3 TMR_2 TMR_3 TMR_2 TMR_3 TMR_2 TMR_3 TMR_2 TMR_3 TMR_2 TMR_3 TPU_4
TPU_5
Rev.2.00 Jun. 28, 2007 Page 610 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Abbreviation DTCERA DTCERB DTCERC DTCERD DTCERE DTCERF DTCERG DTCERH DTCCR INTCR CPUPCR IER ISR PORT1 PORT2 PORT3 PORT4 PORT5 PORT6 PORTA PORTB PORTD PORTE PORTF P1DR P2DR P3DR P6DR
Reset Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Module Sleep Stop State Mode
All-ModuleClock-Stop Mode
Software Standby Mode
Hardware Standby Mode Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Module INTC
I/O port
Rev.2.00 Jun. 28, 2007 Page 611 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Abbreviation PADR PBDR PDDR PEDR PFDR SMR_2 BRR_2 SCR_2 TDR_2 SSR_2 RDR_2 SCMR_2 DADR0 DADR1 DACR01 PCR PMR NDERH NDERL PODRH PODRL NDRH NDRL SMR_0 BRR_0 SCR_0 TDR_0 SSR_0 RDR_0 SCMR_0
Reset Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Module Sleep Stop State Mode Initialized Initialized Initialized Initialized Initialized Initialized
All-ModuleClock-Stop Mode Initialized Initialized Initialized
Software Standby Mode Initialized Initialized Initialized
Hardware Standby Mode Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Module I/O port
SCI_2
D/A
PPG
SCI_0

Initialized Initialized Initialized
Initialized Initialized Initialized
Rev.2.00 Jun. 28, 2007 Page 612 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Abbreviation SMR_1 BRR_1 SCR_1 TDR_1 SSR_1 RDR_1 SCMR_1 ADDRA ADDRB ADDRC ADDRD ADDRE ADDRF ADDRG ADDRH ADCSR ADCR TCSR TCNT RSTCSR TCR_0 TCR_1 TCSR_0 TCSR_1 TCORA_0 TCORA_1 TCORB_0 TCORB_1
Reset Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Module Sleep Stop State Mode Initialized Initialized Initialized
All-ModuleClock-Stop Mode
Software Standby Mode
Hardware Standby Mode Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Module SCI_1

Initialized Initialized Initialized
Initialized Initialized Initialized



A/D
WDT
TMR_0 TMR_1 TMR_0 TMR_1 TMR_0 TMR_1 TMR_0 TMR_1
Rev.2.00 Jun. 28, 2007 Page 613 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Abbreviation TCNT_0 TCNT_1 TCCR_0 TCCR_1 TSTR TSYR TCR_0 TMDR_0 TIORH_0 TIORL_0 TIER_0 TSR_0 TCNT_0 TGRA_0 TGRB_0 TGRC_0 TGRD_0 TCR_1 TMDR_1 TIOR_1 TIER_1 TSR_1 TCNT_1 TGRA_1 TGRB_1 TCR_2 TMDR_2 TIOR_2 TIER_2
Reset Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Module Sleep Stop State Mode
All-ModuleClock-Stop Mode
Software Standby Mode
Hardware Standby Mode Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Module TMR_0 TMR_1 TMR_0 TMR_1 TPU
TPU_0
TPU_1
TPU_2
Rev.2.00 Jun. 28, 2007 Page 614 of 666 REJ09B0311-0200
Section 19 List of Registers
Register Abbreviation TSR_2 TCNT_2 TGRA_2 TGRB_2 TCR_3 TMDR_3 TIORH_3 TIORL_3 TIER_3 TSR_3 TCNT_3 TGRA_3 TGRB_3 TGRC_3 TGRD_3
Reset Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Module Sleep Stop State Mode
All-ModuleClock-Stop Mode
Software Standby Mode
Hardware Standby Mode Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized Initialized
Module TPU_2
TPU_3
Rev.2.00 Jun. 28, 2007 Page 615 of 666 REJ09B0311-0200
Section 19 List of Registers
Rev.2.00 Jun. 28, 2007 Page 616 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
Section 20 Electrical Characteristics
20.1 Absolute Maximum Ratings
Table 20.1 Absolute Maximum Ratings
Item Power supply voltage Input voltage (except port 5) Input voltage (port 5) Reference power supply voltage Analog power supply voltage Analog input voltage Operating temperature Symbol VCC Vin Vin Vref AVCC VAN Topr Value -0.3 to +4.6 -0.3 to VCC +0.3 -0.3 to AVCC +0.3 -0.3 to AVCC +0.3 -0.3 to +4.6 -0.3 to AVCC +0.3 Regular specifications: -20 to +75 Wide-range specifications: -40 to +85 Storage temperature Tstg -55 to +125 C Caution: Permanent damage to the LSI may result if absolute maximum ratings are exceeded. Unit V V V V V V C
Rev.2.00 Jun. 28, 2007 Page 617 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
20.2
DC Characteristics
Table 20.2 DC Characteristics (1) Conditions: VCC = 3.0 V to 3.6 V, AVCC = 3.0 V to 3.6 V, Vref = 3.0 V to AVCC, VSS = AVSS = 0 V*1, Ta = -20C to +75C (regular specifications), Ta = -40C to +85C (wide-range specifications)
Item Schmitt trigger input voltage IRQ input pin, TPU input pin, TMR input pin, port 2, port 3 Port 5*
2
Symbol VT
-
Min. VCC x 0.2
-
Typ.
Max. VCC x 0.7 AVCC x 0.7 VCC + 0.3 VCC + 0.3 VCC + 0.3 AVCC + 0.3 VCC x 0.1 VCC x 0.2 VCC x 0.2 0.4 1.0 10.0 1.0 1.0
Unit V V V V V V V V V V V V V V
Test Conditions
VT
+
VT - VT VT VT
-
+
VCC x 0.06 AVCC x 0.2
+
VT - VT Input high MD, RES, STBY, VIH voltage (except EMLE, NMI Schmitt trigger EXTAL input pin) Other input pins Port 5 Input low MD, RES, STBY, VIL voltage (except EMLE Schmitt trigger EXTAL, NMI input pin) Other pins Output high voltage Output low voltage Input leakage current All output pins VOH
+
-
AVCC x 0.06 VCC x 0.9 VCC x 0.7 VCC x 0.7 AVCC x 0.7 -0.3 -0.3 -0.3 VCC - 0.5 VCC - 1.0
IOH = -200 A IOH = -1 mA
All output pins Port 3 RES MD, STBY, EMLE, NMI Port 5
VOL

V
IOL = 1.6 mA IOL = 10 mA
|Iin|

A
Vin = 0.5 to VCC - 0.5 V
Vin = 0.5 to AVCC - 0.5 V
Rev.2.00 Jun. 28, 2007 Page 618 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
Table 20.2 DC Characteristics (2) Conditions: VCC = 3.0 V to 3.6 V, AVCC = 3.0 V to 3.6 V, Vref = 3.0 V to AVCC, VSS = AVSS = 0 V*1, Ta = -20C to +75C (regular specifications), Ta = -40C to +85C (wide-range specifications)
Item Three-state leakage current (off state) Ports 1 to 3, 6, A, B, D to F, H, I Symbol | ITSI | Min. Typ. Max. 1.0 Unit A Test Conditions Vin = 0.5 to VCC - 0.5 V
Input pull-up Ports D to F, H, I MOS current
-Ip
10
300
A
VCC = 3.0 to 3.6 V Vin = 0 V
Input capacitance Supply 3 current*
All input pins
Cin
15
pF
Vin = 0 V f = 1 MHz Ta = 25C f = 50 MHz
Normal operation Sleep mode Standby mode*
4
ICC*
5

45 (3.3 V) 35 (3.3 V) 0.1 22 1.0 (3.0 V) 0.1 1.5 (3.0 V) 0.4
65 52 0.5 3.0 36 2.0 20 3.0 5.0
mA
Ta 50C 50C < Ta
All-module-clock6 stop mode* Analog power During A/D and D/A AICC supply conversion current Standby for A/D and D/A conversion Reference During A/D and D/A AICC power supply conversion current Standby for A/D and D/A conversion

mA A mA A
Rev.2.00 Jun. 28, 2007 Page 619 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
Item RAM standby voltage Vcc start voltage*
7
Symbol VRAM VCCSTART
Min. 2.5
Typ.
Max. 0.8 20
Unit V V ms/V
Test Conditions
Vcc rising gradient*
7
SVCC
Notes: 1. When the A/D and D/A converters are not used, the AVCC, Vref, and AVSS pins should not be open. Connect the AVCC and Vref pins to VCC, and the AVSS pin to VSS. 2. The case where port 5 is used as IRQ0 to IRQ7. 3. Supply current values are for VIHmin = VCC - 0.5 V and VILmax = 0.5 V with all output pins unloaded and all input pull-up MOSs in the off state. 4. The values are for VRAM VCC < 3.0 V, VIHmin = VCC x 0.9, and VILmax = 0.3 V. 5. ICC depends on VCC and f as follows: ICCmax = 3.0 (mA) + 0.34 (mA/(MHz x V)) x VCC x f (normal operation) ICCmax = 3.0 (mA) + 0.27 (mA/(MHz x V)) x VCC x f (sleep mode) 6. The values are for reference. 7. This can be applied when the RES pin is held low at power-on.
Table 20.3 Permissible Output Currents Conditions: VCC = 3.0 V to 3.6 V, AVCC = 3.0 V to 3.6 V, Vref = 3.0 V to AVCC, VSS = AVSS = 0 V*, Ta = -20C to +75C (regular specifications), Ta = -40C to +85C (wide-range specifications)
Item Permissible output low current (per pin) Permissible output low current (per pin) Permissible output low current (total) Permissible output high current (per pin) Permissible output high current (total) Caution: Note: * Output pins except port 3 Port 3 Total of all output pins All output pins Total of all output pins Symbol IOL IOL IOL -IOH -IOH Min. Typ. Max. 2.0 10 80 2.0 40 Unit mA mA mA mA mA
To protect the LSI's reliability, do not exceed the output current values in table 20.3. When the A/D and D/A converters are not used, the AVCC, Vref, and AVSS pins should not be open. Connect the AVCC and Vref pins to VCC, and the AVSS pin to VSS.
Rev.2.00 Jun. 28, 2007 Page 620 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
20.3
AC Characteristics
3V
RL
LSI output pin
C = 30 pF RL = 2.4 k RH = 12 k Input/output timing measurement level: 1.5 V (Vcc = 3.0 V to 3.6 V) C RH
Figure 20.1 Output Load Circuit
Rev.2.00 Jun. 28, 2007 Page 621 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
20.3.1
Clock Timing
Table 20.4 Clock Timing Conditions: VCC = 3.0 V to 3.6 V, AVCC = 3.0 V to 3.6 V, Vref = 3.0 V to AVCC, VSS = AVSS = 0 V, I = 8 MHz to 50 MHz, B = 8 MHz to 50 MHz, P = 8 MHz to 35 MHz, Ta = -20C to +75C (regular specifications), Ta = -40C to +85C (wide-range specifications)
Item Clock cycle time Clock high pulse width Clock low pulse width Clock rising time Clock falling time Oscillation settling time after reset (crystal) Oscillation settling time after leaving software standby mode (crystal) External clock output delay settling time External clock input low pulse width External clock input high pulse width External clock rising time External clock falling time Symbol tcyc tCH tCL tCr tCf tOSC1 tOSC2 Min. 20.0 5 5 10 10 Max. 125 5 5 Unit. ns ns ns ns ns ms ms Figure 20.4 Figure 20.3 Test Conditions Figure 20.2
tDEXT TEXL TEXH TEXr TEXf
1 27.7 27.7
5 5
ms ns ns ns ns
Figure 20.4 Figure 20.5
tcyc tCH B tCf
tCL
tCr
Figure 20.2 External Bus Clock Timing
Rev.2.00 Jun. 28, 2007 Page 622 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
Oscillator
I
NMI
NMIEG
SSBY NMI exception handling NMI exception handling NMIEG = 1 SSBY = 1 Software standby mode (power-down mode) Oscillation settling time tOSC2
SLEEP instruction
Figure 20.3 Oscillation Settling Timing after Software Standby Mode
EXTAL tDEXT VCC tDEXT
STBY tOSC1 RES tOSC1
I
Figure 20.4 Oscillation Settling Timing
Rev.2.00 Jun. 28, 2007 Page 623 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
tEXH
tEXL
EXTAL
Vcc x 0.5
tEXr
tEXf
Figure 20.5 External Input Clock Timing 20.3.2 Control Signal Timing
Table 20.5 Control Signal Timing Conditions: VCC = 3.0 V to 3.6 V, AVCC = 3.0 V to 3.6 V, Vref = 3.0 V to AVCC, VSS = AVSS = 0 V, I = 8 MHz to 50 MHz, Ta = -20C to +75C (regular specifications), Ta = -40C to +85C (wide-range specifications)
Item RES setup time RES pulse width NMI setup time NMI hold time NMI pulse width (after leaving software standby mode) IRQ setup time IRQ hold time IRQ pulse width (after leaving software standby mode) Symbol tRESS tRESW tNMIS tNMIH tNMIW tIRQS tIRQH tIRQW Min. 200 20 150 10 200 150 10 200 Max. Unit ns tcyc ns ns ns ns ns ns Figure 20.7 Test Conditions Figure 20.6
I tRESS RES tRESW tRESS
Figure 20.6 Reset Input Timing
Rev.2.00 Jun. 28, 2007 Page 624 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
I
tNMIS tNMIH
NMI
tNMIW
IRQi* (i = 0 to 11) IRQ* (edge input)
tIRQW
tIRQS
tIRQH
IRQ* (level input)
tIRQS
Note: * SSIER must be set to cancel software standby mode.
Figure 20.7 Interrupt Input Timing 20.3.3 Bus Timing
Table 20.6 Bus Timing (1) Conditions: VCC = 3.0 V to 3.6 V, AVCC = 3.0 V to 3.6 V, Vref = 3.0 V to AVCC, VSS = AVSS = 0 V, B = 8 MHz to 50 MHz, Ta = -20C to +75C (regular specifications), Ta = -40C to +85C (wide-range specifications)
Item Address delay time Address setup time 1 Address setup time 2 Address setup time 3 Address setup time 4 Address hold time 1 Address hold time 2 Address hold time 3 CS delay time 1 AS delay time Symbol tAD tAS1 tAS2 tAS3 tAS4 tAH1 tAH2 tAH3 tCSD1 tASD Min. 0.5 x tcyc - 8 1.0 x tcyc - 8 1.5 x tcyc - 8 2.0 x tcyc - 8 0.5 x tcyc - 8 1.0 x tcyc - 8 1.5 x tcyc - 8 Max. 15 15 15 Unit ns ns ns ns ns ns ns ns ns ns Test Conditions Figures 20.8 to 20.20
Rev.2.00 Jun. 28, 2007 Page 625 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
Item RD delay time 1 RD delay time 2 Read data setup time 1 Read data setup time 2 Read data hold time 1 Read data hold time 2 Read data access time 2 Read data access time 4 Read data access time 5 Read data access time 6 Read data access time (from address) 1 Read data access time (from address) 2 Read data access time (from address) 3 Read data access time (from address) 4 Read data access time (from address) 5
Symbol tRSD1 tRSD2 tRDS1 tRDS2 tRDH1 tRDH2 tAC2 tAC4 tAC5 tAC6 tAA1 tAA2 tAA3 tAA4 tAA5
Min. 15 15 0 0
Max. 15 15
Unit ns ns ns ns ns ns
Test Conditions Figures 20.8 to 20.20
1.5 x tcyc - 20 ns 2.5 x tcyc - 20 ns 1.0 x tcyc - 20 ns 2.0 x tcyc - 20 ns 1.0 x tcyc - 20 ns 1.5 x tcyc - 20 ns 2.0 x tcyc - 20 ns 2.5 x tcyc - 20 ns
3.0 x tcyc - 18 ns
Rev.2.00 Jun. 28, 2007 Page 626 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
Table 20.6 Bus Timing (2) Conditions: VCC = 3.0 V to 3.6 V, AVCC = 3.0 V to 3.6 V, Vref = 3.0 V to AVCC, VSS = AVSS = 0 V, B = 8 MHz to 50 MHz, Ta = -20C to +75C (regular specifications), Ta = -40C to +85C (wide-range specifications)
Item WR delay time 1 WR delay time 2 WR pulse width 1 WR pulse width 2 Write data delay time Write data setup time 1 Write data setup time 2 Write data setup time 3 Write data hold time 1 Write data hold time 3 Byte control delay time Byte control pulse width 1 Byte control pulse width 2
Multiplexed address delay time 1 Multiplexed address hold time Multiplexed address setup time 1 Multiplexed address setup time 2
Symbol tWRD1 tWRD2 tWSW1 tWSW2 tWDD tWDS1 tWDS2 tWDS3 tWDH1 tWDH3 tUBD tUBW1 tUBW2 tMAD1 tMAH tMAS1 tMAS2 tAHD tAHW1 tAHW2 tWTS tWTH tBREQS tBACD tBZD tBRQOD TBSD TRWD
Min. 1.0 x tcyc - 13 1.5 x tcyc - 13 0.5 x tcyc - 13 1.0 x tcyc - 13 1.5 x tcyc - 13 0.5 x tcyc - 8 1.5 x tcyc - 8 1.0 x tcyc - 15 0.5 x tcyc - 15 1.5 x tcyc - 15 1.0 x tcyc - 15 2.0 x tcyc - 15 15 5.0 20 1.0
Max. 15 15 20 15 1.0 x tcyc - 15 2.0 x tcyc - 15 15 15 15 30 15 15 15
Unit ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns ns
Test Conditions Figures 20.8 to 20.20
Figures 20.13, 20.14 Figure 20.13 Figure 20.14 Figures 20.17, 20.18
Address hold delay time Address hold pulse width 1 Address hold pulse width 2 WAIT setup time WAIT hold time BREQ setup time BACK delay time Bus floating time BREQO delay time BS delay time RD/WR delay time
Figures 20.10, 20.18 Figure 20.19
Figure 20.20 Figures 20.8, 20.9, 20.11 to 20.14
Rev.2.00 Jun. 28, 2007 Page 627 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
T1 B tAD A23 to A0 tCSD1 CS7 to CS0 tAS1 AS tBSD BS tRWD RD/WR tAS1 Read (RDNn = 1) RD tAC5 D15 to D0 tRWD RD/WR tAS1 Read (RDNn = 0) RD tAC2 tAA3 tRWD RD/WR tAS1 LHWR, LLWR Write tWDD D15 to D0 tWSW1 tRSD1 tAA2 tRSD1 tBSD tASD
T2
tASD
tAH1
tRWD
tRSD1
tRDS1 tRDH1
tRWD
tRSD2
tRDS2 tRDH2
D15 to D0
tRWD
tWRD2 tWRD2
tAH1
tWDH1
Figure 20.8 Basic Bus Timing: 2-State Access
Rev.2.00 Jun. 28, 2007 Page 628 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
T1
T2
T3
B
tAD
A23 to A0
tCSD1
CS7 to CS0
tAS1 tASD tASD tAH1
AS
tBSD
tBSD
BS
tRWD tRWD
RD/WR
tAS1 tRSD1 tRSD1
Read (RDNn = 1)
RD
tAC6 tAA4 tRDS1 tRDH1
D15 to D0
tRWD tRWD
RD/WR
tAS1 tRSD1 tRSD2
Read (RDNn = 0)
RD
tAC4 tAA5 tRDS2 tRDH2
D15 to D0
tRWD
tRWD
RD/WR
tAS2 tWRD1 tWRD2 tAH1
Write
LHWR, LLWR
tWDD
tWDS1 tWSW2 tWDH1
D15 to D0
Figure 20.9 Basic Bus Timing: 3-State Access
Rev.2.00 Jun. 28, 2007 Page 629 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
T1 B
T2
Tw
T3
A23 to A0
CS7 to CS0
AS
BS
RD/WR
Read (RDNn = 1)
RD
D15 to D0
RD/WR
Read (RDNn = 0)
RD
D15 to D0
RD/WR
Write
LHWR, LLWR
D15 to D0 tWTS tWTH WAIT tWTS tWTH
Figure 20.10 Basic Bus Timing: Three-State Access, One Wait
Rev.2.00 Jun. 28, 2007 Page 630 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
Th
B
tAD
T1
T2
Tt
A23 to A0
tCSD1
CS7 to CS0
tAS1 tASD tASD tAH1
AS
tBSD
tBSD
BS
tRWD tRWD
RD/WR
tAS3 tRSD1 tRSD1 tAH3
Read (RDNn = 1)
RD
tAC5 tRDS1 tRDH1
D15 to D0
tRWD tRWD
RD/WR
tAS3 tRSD1 tRSD2 tAH2
Read (RDNn = 0)
RD
tAC2 tRDS2 tRDH2
D15 to D0
tRWD
tRWD
RD/WR
tAS3 tWRD2 tWRD2 tAH3
Write
LHWR, LLWR
tWDD tWDS2 tWSW1 tWDH3
D15 to D0
Figure 20.11 Basic Bus Timing: 2-State Access (CS Assertion Period Extended)
Rev.2.00 Jun. 28, 2007 Page 631 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
Th
T1
T2
T3
Tt
B
tAD
A23 to A0
tCSD1
CS7 to CS0
tAS1 tASD AS
tBSD
tBSD
tASD
tAH1
BS
tRWD
tRWD
RD/WR
tAS3
tRSD1
tRSD1
tAH3
Read (RDNn = 1)
RD tAC6 tRDS1 tRDH1
D15 to D0
tRWD RD/WR
tRWD
tAS3
tRSD1
tRSD2
tAH2
Read (RDNn = 0)
RD tAC4 tRDS2 tRDH2
D15 to D0
tRWD RD/WR tRWD
tAS4
tWRD2 tWRD1 tWDS3
tAH3
Write
LHWR, LLWR
tWDD
tWSW2
tWDH3
D15 to D0
Figure 20.12 Basic Bus Timing: 3-State Access (CS Assertion Period Extended)
Rev.2.00 Jun. 28, 2007 Page 632 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
T1 B tAD A23 to A0 tCSD1 CS7 to CS0 tAS1 AS tBSD BS tRWD RD/WR tAS1 tRSD1 tASD tASD
T2
tAH1
tBSD
tRWD
tRSD1
Read
RD tAC5 tRDS1 tRDH1 D15 to D0 tAA2 tAC5 tUBD LUB, LLB tAS1 tRWD RD/WR tUBW1 tAH1 tRWD tUBD
Write
RD
High tWDD tWDH1
D15 to D0
Figure 20.13 Byte Control SRAM: 2-State Read/Write Access
Rev.2.00 Jun. 28, 2007 Page 633 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
T1 B tAD A23 to A0 tCSD1 CS7 to CS0 tAS1 tASD AS tBSD BS tRWD RD/WR tAS1 tRSD1 Read RD tBSD
T2
T3
tASD
tAH1
tRWD
tRSD1
tAC6 tAA4 D15 to D0 tAC6 tUBD LUB, LLB tAS1 tRWD RD/WR tUBW2
tRDS1 tRDH1
tUBD tAH1 tRWD
Write
RD
High tWDD tWDH1
D15 to D0
Figure 20.14 Byte Control SRAM: 3-State Read/Write Access
Rev.2.00 Jun. 28, 2007 Page 634 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
T1 B
T2
T1
T1
A23 to A6, A0 tAD A5 to A1
CS7 to CS0
AS
BS
RD/WR tRSD2 Read RD tAA1 tRDS2 tRDH2 D15 to D0
LHWR, LLWR
High
Figure 20.15 Burst ROM Access Timing: 1-State Burst Access
Rev.2.00 Jun. 28, 2007 Page 635 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
T1 B
T2
T3
T1
T2
A23 to A6, A0 tAD A5 to A1
CS7 to CS0 tAS1 AS tASD tASD tAH1
BS
RD/WR tRSD2 Read RD tAA3 D15 to D0 tRDS2 tRDH2
LHWR, LLWR
High
Figure 20.16 Burst ROM Access Timing: 2-State Burst Access
Rev.2.00 Jun. 28, 2007 Page 636 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
Tma1 B
Tma2
T1
T2
tAD
A23 to A0
CS7 to CS0
tAHD
AH (AS)
tAHD
tAHW1
RD/WR
Read
RD
tMAS1 tMAD1
D15 to D0
tMAH
tRDS2
tRDH2
RD/WR
tWSW1
Write LHWR, LLWR
tMAS1 tMAD1
D15 to D0
tMAH tWDD tWDH1
BS
Figure 20.17 Address/Data Multiplexed Access Timing (No Wait) (Basic, 4-State Access)
Rev.2.00 Jun. 28, 2007 Page 637 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
Tma1 B tAD A23 to A0
Tmaw
Tma2
T1
T2
Tpw
Ttw
T3
CS7 to CS0 tAHD AH (AS) RD/WR tAHD tAHW2
Read
RD tMAD1 D15 to D0
tMAS2
tMAH tRDS2 tRDH2
RD/WR
Write
LHWR, LLWR tMAD1 D15 to D0
tMAS2
tMAH tWDS1 tWDH1
tWDD WAIT
tWTS tWTH tWTS tWTH
Figure 20.18 Address/Data Multiplexed Access Timing (Wait Control) (Address Cycle Program Wait x 1 + Data Cycle Program Wait x 1 + Data Cycle Pin Wait x 1)
Rev.2.00 Jun. 28, 2007 Page 638 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
B tBREQS BREQ tBACD BACK tBZD A23 to A0 tBZD tBACD tBREQS
CS7 to CS0
D15 to D0 AS, RD, LHWR, LLWR
Figure 20.19 External Bus Release Timing
B
BACK tBRQOD BREQO tBRQOD
Figure 20.20 External Bus Request Output Timing
Rev.2.00 Jun. 28, 2007 Page 639 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
20.3.4
Timing of On-Chip Peripheral Modules
Table 20.7 Timing of On-Chip Peripheral Modules Conditions: VCC = 3.0 V to 3.6 V, AVCC = 3.0 V to 3.6 V, Vref = 3.0 V to AVCC, VSS = AVSS = 0 V, P = 8 MHz to 35 MHz, Ta = -20C to +75C (regular specifications), Ta = -40C to +85C (wide-range specifications)
Item I/O ports Output data delay time Input data setup time Input data hold time TPU Timer output delay time Timer input setup time Timer clock input setup time Timer clock pulse width Single-edge setting Both-edge setting PPG 8-bit timer Pulse output delay time Timer output delay time Timer reset input setup time Timer clock input setup time Timer clock pulse width Single-edge setting Both-edge setting WDT SCI Overflow output delay time Input clock cycle Asynchronous Clocked synchronous tSCKW tSCKr tSCKf Symbol tPWD tPRS tPRH tTOCD tTICS tTCKS tTCKWH tTCKWL tPOD tTMOD tTMRS tTMCS tTMCWH tTMCWL tWOVD tScyc Min. 25 25 25 25 1.5 2.5 25 25 1.5 2.5 4 6 0.4 Max. 40 40 40 40 40 0.6 1.5 1.5 tScyc tcyc tcyc Unit ns ns ns ns ns ns tcyc tcyc ns ns ns ns tcyc tcyc ns tcyc Figure 20.28 Figure 20.29 Figure 20.24 Figure 20.25 Figure 20.26 Figure 20.27 Figure 20.23 Figure 20.22 Test Conditions Figure 20.21
Input clock pulse width Input clock rise time Input clock fall time
Rev.2.00 Jun. 28, 2007 Page 640 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
Item SCI Transmit data delay time Receive data setup time (clocked synchronous) Receive data hold time (clocked synchronous) A/D Trigger input setup time converter
Symbol tTXD tRXS tRXH tTRGS
Min. 40 40 30
Max. 40
Unit ns ns ns ns
Test Conditions Figure 20.30
Figure 20.31
T1
T2
P tPRS tPRH Ports 1 to 3, 5, 6, A, B, D to F, H, I (read) tPWD Ports 1 to 3, 6, A, B, D to F, H, I (write)
Figure 20.21 I/O Port Input/Output Timing
P tTOCD Output compare output* tTICS Input capture input* Note: * TIOCA0 to TIOCA5, TIOCB0 to TIOCB5, TIOCC0, TIOCC3, TIOCD0, TIOCD3
Figure 20.22 TPU Input/Output Timing
P tTCKS TCLKA to TCLKD tTCKWL tTCKWH tTCKS
Figure 20.23 TPU Clock Input Timing
Rev.2.00 Jun. 28, 2007 Page 641 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
P tPOD PO15 to PO0
Figure 20.24 PPG Output Timing
P tTMOD TMO0 to TMO3
Figure 20.25 8-Bit Timer Output Timing
P tTMRS TMRI0 to TMRI3
Figure 20.26 8-Bit Timer Reset Input Timing
P tTMCS TMCI0 to TMCI3 tTMCWL tTMCWH tTMCS
Figure 20.27 8-Bit Timer Clock Input Timing
P tWOVD WDTOVF tWOVD
Figure 20.28 WDT Output Timing
Rev.2.00 Jun. 28, 2007 Page 642 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
tSCKW SCK0 to SCK2, SCK4
tSCKr
tSCKf
tScyc
Figure 20.29 SCK Clock Input Timing
SCK0 to SCK2, SCK4 TxD0 to TxD2, TxD4 (transmit data) RxD0 to RxD2, RxD4 (receive data)
tTXD
tRXS tRXH
Figure 20.30 SCI Input/Output Timing: Clocked Synchronous Mode
P tTRGS ADTRG0
Figure 20.31 A/D Converter External Trigger Input Timing
Rev.2.00 Jun. 28, 2007 Page 643 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
20.4
A/D Conversion Characteristics
Table 20.8 A/D Conversion Characteristics Conditions: VCC = 3.0 V to 3.6 V, AVCC = 3.0 V to 3.6 V, Vref = 3.0 V to AVCC, VSS = AVSS = 0 V, P = 8 MHz to 35 MHz, Ta = -20C to +75C (regular specifications), Ta = -40C to +85C (wide-range specifications)
Item Resolution Conversion time Analog input capacitance Permissible signal source impedance Nonlinearity error Offset error Full-scale error Quantization error Absolute accuracy Min. 10 7.4 Typ. 10 0.5 Max. 10 20 10 7.5 7.5 7.5 8.0 Unit Bit s pF k LSB LSB LSB LSB LSB
Rev.2.00 Jun. 28, 2007 Page 644 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
20.5
D/A Conversion Characteristics
Table 20.9 D/A Conversion Characteristics Conditions: VCC = 3.0 V to 3.6 V, AVCC = 3.0 V to 3.6 V, Vref = 3.0 V to AVCC, VSS = AVSS = 0 V, P = 8 MHz to 35 MHz, Ta = -20C to +75C (regular specifications), Ta = -40C to +85C (wide-range specifications)
Item Resolution Conversion time Absolute accuracy Min. 8 Typ. 8 2.0 Max. 8 10 3.0 2.0 Unit Bit s LSB LSB 20-pF capacitive load 2-M resistive load 4-M resistive load Test Conditions
Rev.2.00 Jun. 28, 2007 Page 645 of 666 REJ09B0311-0200
Section 20 Electrical Characteristics
Rev.2.00 Jun. 28, 2007 Page 646 of 666 REJ09B0311-0200
Appendix
Appendix
A. Port States in Each Pin State
Port States in Each Pin State
MCU Operating Mode All All All All All Hardware Standby Mode Hi-Z Hi-Z Hi-Z Hi-Z Hi-Z Software Standby Mode OPE = 1 Keep Keep Keep Hi-Z [DAOE0 = 1] Keep [DAOE0 = 0] Hi-Z P57/ AN7/ DA1/ IRQ7-B P65 to P60 PA0/ BREQO/ BS-A All Hi-Z Hi-Z [DAOE1 = 1] Keep [DAOE1 = 0] Hi-Z All All Hi-Z Hi-Z Hi-Z Hi-Z Keep [BREQO output] Hi-Z [BS output] Keep [Other than above] Keep PA1/ BACK/ (RD/WR) All Hi-Z Hi-Z [BACK output] Hi-Z [RD/WR output] Keep [Other than above] Keep OPE = 0 Keep Keep Keep Hi-Z [DAOE0 = 1] Keep [DAOE0 = 0] Hi-Z [DAOE1 = 1] Keep [DAOE1 = 0] Hi-Z Keep [BREQO output] Hi-Z [BS output] Hi-Z [Other than above] Keep [BACK output] Hi-Z [RD/WR output] Hi-Z [Other than above] Keep Keep [BREQO output] BREQO [BS output] Hi-Z [Other than above] Keep [BACK output] BACK [RD/WR output] Hi-Z [Other than above] Keep Keep Bus Released State Keep Keep Keep Keep Keep
Table A.1
Port Name Port 1 Port 2 Port 3 P55 to P50 P56/ AN6/ DA0/ IRQ6-B
Reset Hi-Z Hi-Z Hi-Z Hi-Z Hi-Z
Rev.2.00 Jun. 28, 2007 Page 647 of 666 REJ09B0311-0200
Appendix
Hardware Standby Mode Hi-Z Software Standby Mode OPE = 1 [BREQ input] Hi-Z [WAIT input] Hi-Z [Other than above] Keep PA3/ LLWR/ LLB PA4/ LHWR/ LUB External extended H mode External extended H mode Hi-Z H OPE = 0 [BREQ input] Hi-Z [WAIT input] Hi-Z [Other than above] Keep Hi-Z Bus Released State [BREQ input] Hi-Z (BREQ) [WAIT input] Hi-Z (WAIT) [Other than above] Keep Hi-Z
Port Name PA2/ BREQ/ WAIT
MCU Operating Mode All
Reset Hi-Z
Hi-Z
[LHWR, LUB output] [LHWR, LUB output] [LHWR, LUB output] Hi-Z H [Other than above] Keep [Other than above] Keep Hi-Z [AS, AH, BS output] Hi-Z [Other than above] Keep Hi-Z [Other than above] Keep
PA5/RD PA6/ AS/ AH/ BS-B
External extended H mode External extended H mode
Hi-Z Hi-Z
H [AS, BS output] H [AH output] L [Other than above] Keep
Hi-Z [AS, AH, BS output] Hi-Z [Other than above] Keep
PA7/B
External extended Clock mode output
Hi-Z
[Clock output] H [Other than above] Keep
[Clock output] H [Other than above] Keep [CS output] Hi-Z [Other than above] Keep [CS output] Hi-Z [Other than above] Keep
[Clock output] Clock output [Other than above] Keep [CS output] Hi-Z [Other than above] Keep [CS output] Hi-Z [Other than above] Keep
PB0/ CS0/ CS4-A/ CS5-B PB1/ CS1/ CS2-B/ CS5-A/ CS6-B/ CS7-B
External extended H mode
Hi-Z
[CS output] H [Other than above] Keep
All
Hi-Z
Hi-Z
[CS output] H [Other than above] Keep
Rev.2.00 Jun. 28, 2007 Page 648 of 666 REJ09B0311-0200
Appendix
Hardware MCU Operating Port Name PB2/ CS2-A/ CS6-A Mode All Reset Hi-Z Standby Mode Hi-Z OPE = 1
Software Standby Mode Bus OPE = 0 [CS output] Hi-Z [Other than above] Keep [CS output] Hi-Z [Other than above] Keep Hi-Z Released State [CS output] Hi-Z [Other than above] Keep [CS output] Hi-Z [Other than above] Keep Hi-Z
[CS output] H [Other than above] Keep
PB3/ CS3/ CS7-A
All
Hi-Z
Hi-Z
[CS output] H [Other than above] Keep
Port D
External extended L mode
Hi-Z
Keep
Port E
External extended L mode
Hi-Z Hi-Z
Keep Keep
Hi-Z [Address output] Hi-Z [Other than above] Keep
Hi-Z [Address output] Hi-Z [Other than above] Keep [Address output] Hi-Z [CS output] Hi-Z* [Other than above] Keep Hi-Z
PF0 to PF4 External extended L mode
PF5/CS5-D/ External extended Hi-Z PF6/CS6-D/ mode PF7/CS4-C/ CS5-C/ CS6-C/ CS7-C
Hi-Z
[Address output] Keep [CS output] H* [Other than above] Keep
[Address output] Hi-Z [CS output] Hi-Z* [Other than above] Keep Hi-Z
Port H
External extended Hi-Z mode
Hi-Z
Hi-Z
Port I
External extended mode
8-bit bus mode 16-bit bus mode
Hi-Z
Hi-Z
Keep
Keep
Keep
Hi-Z
Hi-Z
Hi-Z
Hi-Z
Hi-Z
[Legend] H: L: Keep: Hi-Z: High level Low level Input ports become high-impedance, and output ports retain the state. High impedance
Rev.2.00 Jun. 28, 2007 Page 649 of 666 REJ09B0311-0200
Appendix
B.
Product Lineup
Product Classification Product Model Marking Package (Package Code) ROMless R5S61650CFPV R5S61650CFPV PLQP0120LA-A (FP-120BV)
H8SX/1650C
Rev.2.00 Jun. 28, 2007 Page 650 of 666 REJ09B0311-0200
C.
JEITA Package Code PLQP0120LA-A 120P6R-A / FP-120B / FP-120BV 0.7g
RENESAS Code
Previous Code
MASS[Typ.]
P-LQFP120-14x14-0.40
HD *1 D 61
90
91
60
Package Dimensions
bp b1
E HE
NOTE) 1. DIMENSIONS "*1" AND "*2" DO NOT INCLUDE MOLD FLASH. 2. DIMENSION "*3" DOES NOT INCLUDE TRIM OFFSET.
c
*2
Terminal cross section
Reference Symbol
c1
Dimension in Millimeters Min D E 13.9 13.9 A2 HD 15.8 HE 15.8 Nom 14.0 14.0 1.4 16.0 16.0 16.2 16.2 Max 14.1 14.1
120
ZE
31
30
1 ZD F
A A2
Index mark
A
c
1.7 A1 bp
A1
0.05 0.13 L L1 b1 c c1 Detail F e x y ZD ZE L L1 0.35 0 0.09
0.1 0.18 0.16 0.145 0.125
0.15 0.23
For the package dimensions, data in the Renesas IC Package General Catalog has priority.
Figure C.1 Package Dimensions (FP-120BV)
y *3 bp x
0.20
e
8 0.4 0.07 0.08 1.2 1.2 0.5 1.0 0.65
Appendix
Rev.2.00 Jun. 28, 2007 Page 651 of 666
REJ09B0311-0200
Appendix
D.
Treatment of Unused Pins
The treatments of unused pins are listed in table D.1. Table D.1
Pin Name RES STBY EMLE MD2, MD1, MD0 NMI EXTAL XTAL WDTOVF Port 1 Port 2 Port 3 Port 6 PA2 to PA0 PB3 to PB0 PF7 to PF5 Port 5 PA7 PA6 PA5 PA4 PA3 PB0 * * * * * * * Connect each pin to AVCC via a pull-up resistor or to AVSS via a pull-down resistor Since this is the B output in its initial state, leave the pin unconnected. Since this is the AS output in its initial state, leave the pin unconnected. Since this is the RD output in its initial state, leave the pin unconnected. Since this is the LHWR output in its initial state, leave the pin unconnected. Since this is the LLWR output in its initial state, leave the pin unconnected. Since this is the CS0 output in its initial state, leave the pin unconnected.
Treatment of Unused Pins
Mode 4 (Always used as a reset pin) * * * * * * Connect to VCC via a pull-up resistor Connect to VSS via a pull-down resistor Connect to VCC via a pull-up resistor Leave the pin unconnected Leave the pin unconnected Connect each pin to VCC via a pull-up resistor or to VSS via a pull-down resistor Mode 5
(Always used as operating mode pins)
(Always used as a clock pin)
Rev.2.00 Jun. 28, 2007 Page 652 of 666 REJ09B0311-0200
Appendix
Pin Name Port D Port E PF4 to PF0 Port H Port I
Mode 4 *
Mode 5
Since this is the address output in its initial state, leave the pin unconnected.
(Used as a data bus) (Used as a data bus) Since this is a general-purpose input port in its initial state, connect each pin to VCC via a pull-up resistor or connect each pin to VSS via a pulldown resistor.
Vref
*
Connect to AVCC
Notes: 1. Do not change the initial value (input-buffer disabled) of PnICR, where n corresponds to an unused pin. 2. When changing the pin function from its initial state, use a pull-up or pull-down resistor as needed.
Rev.2.00 Jun. 28, 2007 Page 653 of 666 REJ09B0311-0200
Appendix
Rev.2.00 Jun. 28, 2007 Page 654 of 666 REJ09B0311-0200
Main Revisions and Additions in this Edition
Main Revisions and Additions in this Edition
Item All Page Revision (See Manual for Details) Modified Type classification changed (from H8SX/1650A to H8SX/1650C). Type name and mark name changed (from R5S61650AFPV to R5S61650CFPV). 1.1 Features 1 Modified Notes: The following additions and changes have been made in the switch from the H8SX/1650A to the H8SX/1650C. * The chip select signal is added to PF7, PF6, and PF5. Table 1.1 Overview of Functions 6 Modified
Module/ Classification Function Description : * Supply current: 45 mA (typ.) (Vcc = 3.3 V, Avcc = 3.3 V, I = B = 50 MHz, P = 25 MHz)
Operating frequency/Power supply voltage
Figure 1.3 Pin Assignments
9
Modified
Vcc PB0/CS0/CS4-A/CS5-B
119 120
Rev.2.00 Jun. 28, 2007 Page 655 of 666 REJ09B0311-0200
PB1/CS1/CS2-B/CS5-A/CS6-B/CS7-B PB2/CS2-A/CS6-A PB3/CS3/CS7-A MD2 PF7/A23/CS4-C/CS5-C/CS6-C/CS7-C PF6/A22/CS6-D PF5/A21/CS5-D PF4/A20
1 2 3 4 5 6 7 8
Main Revisions and Additions in this Edition
Item Table 1.3 Pin Functions
Page Revision (See Manual for Details) 11 Modified
Classification
Bus control
Pin Name
CS0 CS1 CS2-A/CS2-B CS3 CS4-A/CS4-C CS5-A/CS5-B/ CS5-C/CS5-D CS6-A/CS6-B/ CS6-C/CS6-D CS7-A/CS7-B/ CS7-C
Table 3.3 Pin Functions in Each 67 Operating Mode (Advanced Mode)
Modified
Port Port A PA7 PA6, PA4 PA2 to PA0 Port B PB3 to 1 PB0 Mode 4 P/C* P/C* P*/C P*/C P/C* Mode 5 P/C* P/C* P*/C P*/C P/C*
Figure 3.1 Address Map (Advanced Mode)
68
Deleted Notes: In the H8SX/1650, space from H'FFC000 to H'FF6000 was specified as the external address space. In the H8SX/1650C, space from H'FF0000 to H'FF6000 is specified as the access-prohibited space. * This area is specified as the external address space by clearing the RAME bit in SYSCR to 0.
Table 8.1 Port Functions
255, 256
Modified
Function Port Port B Port F Bit 0 7 I/O PB0 PF7 Input Output CS0/CS4-A/CS5-B A23/CS4-C/CS5-C/ CS6-C/CS7-C 6 5 PF6 PF5 A22/CS6-D A21/CS5-D
Rev.2.00 Jun. 28, 2007 Page 656 of 666 REJ09B0311-0200
Main Revisions and Additions in this Edition
Item 8.2.7 Port B (4) PB0/CS0/CS4-A/CS5-B
Page Revision (See Manual for Details) 281 Modified
Setting Module Name Bus controller Pin Function CS0 output (initial setting) CS4-A output 1 CS0_OE 1 I/O Port CS4-A_OE
8.2.10 Port F (1) PF7/A23/CS4-C/CS5-C/ CS6-C/CS7-C
283
Added
Setting I/O Port Module Name Bus controller Pin Function A23 output CS4-C output CS5-C output CS6-C output CS7-C output 0 1 0 1 0 1 0 1 A23_ OE 1 CS4-C output CS5-C output CS6-C output CS7-C output
8.2.10 Port F (2) PF6/A22/CS6-D
283
Added
Setting Module Name Bus controller I/O port Pin Function A22 output CS6-D output PF6 output PF6 input (initial setting) A22_OE 1 0 0 0 I/O Port CS6D_OE 1 0 0 PF6DDR 1 0
Rev.2.00 Jun. 28, 2007 Page 657 of 666 REJ09B0311-0200
Main Revisions and Additions in this Edition
Item 8.2.10 Port F (3) PF5/A21/CS5-D
Page Revision (See Manual for Details) 284 Added
Setting Module Name Bus controller I/O port Pin Function A21 output CS5-D output PF5 output PF5 input (initial setting) A21_OE 1 0 0 0 I/O Port CS5D_OE 1 0 0 PF5DDR 1 0
Table 8.5 Available Output Signals 290, and Settings in Each Port 291
Modified
Signal Output Specification Port PB 0 Signal Name CS4A_OE Output Signal Name CS4 Selection Register Settings PFCR1.CS 4S[A,B] = 00 PFCR0.CS 4E = 1 PF 7 A23_OE CS4C_OE CS5C_OE CS6C_OE CS7C_OE A23 CS4 CS5 CS6 CS7 PFCR4.A23E = 1 PFCR1.CS4S[A,B] = 10 PFCR0.CS4E = 1 PFCR1.CS5S[A,B] = 10 PFCR0.CS5E = 1 PFCR1.CS6S[A,B] = 10 PFCR0.CS6E = 1 PFCR1.CS7S[A,B] = 10 PFCR0.CS7E = 1 6 A22_OE CS6D_OE A22 CS6 PFCR4.A22E = 1 PFCR1.CS6S[A,B] = 11 PFCR0.CS6E = 1 5 A21_OE CS5D_OE A21 CS5 PFCR4.A21E = 1 PFCR1.CS5S[A,B] = 11 PFCR0.CS5E = 1 Peripheral Module Settings PFCR0.CS4E = 1
Rev.2.00 Jun. 28, 2007 Page 658 of 666 REJ09B0311-0200
Main Revisions and Additions in this Edition
Item 8.3.2 Port Function Control Register 1 (PFCR1)
Page Revision (See Manual for Details) 293, 294 Modified
2 CS5SB 0 R/W 1 CS4SA 0 R/W
0 CS4SB 0 R/W
Bit 7 6
Bit Name CS7SA* CS7SB*
Description CS7 Output Pin Select : 10: Specifies pin PF7 as CS7-C output 11: Setting prohibited
5 4
CS6SA* CS6SB*
CS6 Output Pin Select : 10: Specifies pin PF7 as CS6-C output 11: Specifies pin PF6 as CS6-D output
3 2
CS5SA* CS5SB*
CS5 Output Pin Select : 10: Specifies pin PF7 as CS5-C output 11: Specifies pin PF5 as CS5-D output
1 0
CS4SA* CS4SB*
CS4 Output Pin Select Selects the output pin for CS4 when CS4 output is enabled (CS4E = 1) 00: Specifies pin PB0 as CS4-A output 01: Setting prohibited 10: Specifies pin PF7 as CS4-C output 11: Setting prohibited
Note: * If multiple CS outputs are specified to a single pin according to the CSn output pin select bits (n = 4 to 7), ... 17.5.1 Notes on Clock Pulse Generator 559 Deleted 4. Note that the frequency of f will be changed in the middle of a bus cycle when setting SCKCR while executing the external bus cycle with the write-databuffer function. 598 Modified
Register Abbreviation PFCR1 Bit 25/17/9/1 CS4SA Bit 24/16/8/0 CS4SB Module I/O port
19.2 Register Bits
Rev.2.00 Jun. 28, 2007 Page 659 of 666 REJ09B0311-0200
Main Revisions and Additions in this Edition
Item
Page Revision (See Manual for Details) Modified
MCU Operating Port Name PB0/ CS0/ CS4-A/ CS5-B Mode External extended mode [Other than above] Keep PF0 to PF4 External extended mode L Hi-Z Keep [Address output] Hi-Z [Other than above] Keep PF5/CS5-D/ PF6/CS6-D/ PF7/CS4-C/ CS5-C/ CS6-C/ CS7-C [CS output] H* [Other than above] Keep [CS output] Hi-Z* [Other than above] Keep [CS output] Hi-Z* [Other than above] Keep External extended mode Hi-Z Hi-Z [Address output] Keep [Address output] Hi-Z [Other than above] Keep [Address output] Hi-Z [Other than above] Keep [Address output] Hi-Z Reset H Hardware Standby Mode Hi-Z OPE = 1 [CS output] H OPE = 0 Software Standby Mode Bus Released State [CS output] Hi-Z
Table A.1 Port States in Each Pin 648, State 649
Rev.2.00 Jun. 28, 2007 Page 660 of 666 REJ09B0311-0200
Index
Numerics
0-output/1-output .................................... 349 16-bit access space.................................. 165 16-bit counter mode................................ 430 16-bit timer pulse unit (TPU) ................. 305 8-bit access space.................................... 164 8-bit timers (TMR) ................................. 411 Basic bus interface .......................... 157, 167 Big endian ............................................... 156 Bit rate..................................................... 471 Block diagram............................................. 8 Block transfer mode ................................ 239 Burst ROM interface....................... 157, 185 Bus arbitration......................................... 213 Bus configuration.................................... 145 Bus controller (BSC)............................... 121 Bus cycle division ................................... 233 Bus width ................................................ 156 Bus-released state...................................... 59 Byte control SRAM interface ......... 157, 179
A
A/D conversion accuracy........................ 538 A/D converter ......................................... 525 Absolute accuracy................................... 538 Address error ............................................ 76 Address map ............................................. 68 Address/data multiplexed I/O interface.................................... 158, 189 Addressing modes..................................... 50 All-module-clock-stop mode .......... 564, 575 Area 0 ..................................................... 159 Area 1 ..................................................... 159 Area 2 ..................................................... 160 Area 3 ..................................................... 160 Area 4 ..................................................... 161 Area 5 ..................................................... 161 Area 6 ..................................................... 162 Area 7 ..................................................... 163 Area division........................................... 153 Asynchronous mode ............................... 481 AT-cut parallel-resonance type............... 557 Available output signal and settings in each port ......................... 287 Average transfer rate generator............... 450
C
Cascaded connection............................... 430 Cascaded operation ................................. 357 Chain transfer.......................................... 240 Chip select signals................................... 154 Clock pulse generator ............................. 553 Clock synchronization cycle (Tsy).......... 147 Clocked synchronous mode .................... 498 Compare match A ................................... 428 Compare match B ................................... 428 Compare match count mode ................... 430 Compare match signal............................. 427 CPU priority control function over DTC .................................. 115 Crystal resonator ..................................... 557
D
D/A converter ......................................... 545 Data direction register............................. 258 Data register............................................ 259 Data transfer controller (DTC)................ 217
Rev.2.00 Jun. 28, 2007 Page 661 of 666 REJ09B0311-0200
B
B clock output control .......................... 585
Data transfer instructions.......................... 39 Direct convention ................................... 507 Double-buffered structure....................... 481 DTC vector address ................................ 229 DTC vector address offset ...................... 229
I
I/O ports .................................................. 251 ID code.................................................... 492 Idle cycle................................................. 198 Illegal instruction ...................................... 81 Index register ............................................ 25 Initial register values................................. 29 Input buffer control register .................... 260 Internal interrupts.................................... 101 Internal peripheral bus ............................ 145 Internal system bus ................................. 145 Interrupt .................................................... 78 Interrupt control mode 0 ......................... 106 Interrupt control mode 2 ......................... 108 Interrupt controller.................................... 85 Interrupt exception handling sequence ... 110 Interrupt exception handling vector table.............................................. 102 Interrupt response times.......................... 111 Interrupt sources ..................................... 100 Interrupt sources and vector address offsets......................................... 102 Interval timer .......................................... 444 Interval timer mode................................. 444 Inverse convention.................................. 508 IRQn interrupts ....................................... 100
E
Effective address ...................................... 56 Endian and data alignment ..................... 163 Endian format ......................................... 156 Error signal ............................................. 507 Exception handling ................................... 69 Exception handling vector table ............... 70 Exception-handling state .......................... 59 Extension of chip select (CS) assertion period....................................... 177 External access bus................................. 145 External bus ............................................ 150 External bus clock (B) .................. 146, 553 External bus interface ............................. 155 External clock......................................... 558 External interrupts .................................. 100
F
Free-running count operation ................. 347 Frequency divider ................................... 553 Full address mode................................... 228 Full-scale error........................................ 538
L
Little endian ............................................ 156
G
General registers ....................................... 25
M
Mark state ....................................... 481, 519 MCU operating modes.............................. 61 Memory map............................................. 23 Mode 4 ...................................................... 66 Mode 5 ...................................................... 66 Mode pin................................................... 61 Module stop function .............................. 573
H
Hardware standby mode ................. 564, 580
Rev.2.00 Jun. 28, 2007 Page 662 of 666 REJ09B0311-0200
Module stop mode .................................. 583 Multi-clock mode ................................... 573 Multiprocessor bit................................... 492 Multiprocessor communication function................................................... 492
Pull-up MOS control register.................. 261
Q
Quantization error ................................... 538
N
NMI interrupt.......................................... 100 Nonlinearity error ................................... 538 Non-overlapping..................................... 404 Normal transfer mode ............................. 236
R
RAM ....................................................... 551 Read strobe (RD) timing ......................... 176 Register addresses................................... 588 Register bits ............................................ 597 Register configuration in each port ......... 257 Registers ABWCR...................... 124, 590, 599, 609 ADCR ......................... 531, 594, 604, 613 ADCSR ....................... 529, 594, 604, 613 ADDR ......................... 528, 594, 603, 613 ASTCR........................ 126, 590, 599, 609 BCR1 .......................... 137, 590, 599, 609 BCR2 .......................... 139, 590, 599, 609 BROMCR ................... 142, 590, 599, 609 BRR ............................ 471, 594, 603, 612 CCR ...................................................... 26 CPUPCR ....................... 89, 592, 602, 611 CRA .................................................... 224 CRB .................................................... 224 CSACR ....................... 133, 590, 599, 609 DACR01 ..................... 547, 593, 603, 612 DADR0 ....................... 546, 593, 603, 612 DADR1 ....................... 546, 593, 603, 612 DAR.................................................... 223 DDR............................ 258, 588, 597, 607 DR............................... 259, 588, 597, 607 DTCCR ....................... 226, 592, 602, 611 DTCER ....................... 225, 592, 601, 611 DTCVBR .................... 227, 590, 599, 609 ENDIANCR................ 140, 590, 599, 609 EXR ...................................................... 28 ICR.............................. 260, 588, 597, 607
Rev.2.00 Jun. 28, 2007 Page 663 of 666 REJ09B0311-0200
O
Offset error ............................................. 538 On-chip baud rate generator ................... 484 On-chip ROM disabled extended mode.... 61 Open-drain control register..................... 262 Oscillator ................................................ 557 Output buffer control .............................. 262 Output trigger ......................................... 404 Overflow......................................... 429, 442
P
Package dimensions................................ 651 Parity bit ................................................. 481 Peripheral module clock (P) ......... 146, 553 Pin assignments .......................................... 9 Pin functions ............................................. 10 PLL circuit...................................... 553, 558 Port function controller........................... 292 Port register............................................. 259 Power-down states .................................. 563 Processing states ....................................... 59 Product lineup......................................... 650 Program execution state............................ 59 Program stop state .................................... 59 Programmable pulse generator (PPG) .... 389
IDLCR .........................135, 590, 599, 609 IER.................................92, 592, 602, 611 INTCR ...........................88, 592, 602, 611 IPR.................................90, 589, 598, 608 ISCRH ...........................94, 589, 599, 608 ISCRL............................94, 589, 599, 608 ISR.................................98, 592, 602, 611 MAC..................................................... 29 MDCR ...........................62, 590, 600, 609 MPXCR .......................144, 590, 599, 609 MRA................................................... 220 MRB ................................................... 221 MSTPCRA ..................569, 590, 600, 609 MSTPCRB...................569, 590, 600, 609 MSTPCRC...................572, 590, 600, 609 NDERH .......................392, 593, 603, 612 NDERL........................392, 593, 603, 612 NDRH..........................395, 593, 603, 612 NDRL ..........................395, 593, 603, 612 ODR.............................262, 589, 598, 608 PC ......................................................... 26 PCR .....................261, 398, 593, 603, 612 PFCR0 .........................292, 589, 598, 608 PFCR1 .........................293, 589, 598, 608 PFCR2 .........................294, 589, 598, 608 PFCR4 .........................297, 589, 598, 608 PFCR6 .........................298, 589, 598, 608 PFCR9 .........................299, 589, 598, 608 PFCRB................................................ 301 PFCRC.........................302, 589, 598, 608 PMR.............................399, 593, 603, 612 PODRH .......................394, 593, 603, 612 PODRL ........................394, 593, 603, 612 PORT...........................259, 592, 602, 611 RDNCR .......................132, 590, 599, 609 RDR.............................454, 594, 603, 612 RSR .................................................... 454 RSTCSR ......................441, 594, 604, 613 SAR .................................................... 223 SBR ...................................................... 28
Rev.2.00 Jun. 28, 2007 Page 664 of 666 REJ09B0311-0200
SBYCR ....................... 566, 590, 600, 609 SCKCR ....................... 554, 590, 600, 609 SCMR ......................... 470, 594, 603, 612 SCR............................. 458, 594, 603, 612 SEMR ......................... 479, 590, 600, 609 SMR............................ 455, 594, 603, 612 SRAMCR.................... 141, 590, 599, 609 SSIER ........................... 99, 589, 598, 608 SSR ............................. 463, 594, 603, 612 SYSCR.......................... 64, 590, 600, 609 TCCR.......................... 419, 595, 604, 614 TCNT.......... 343, 416, 438, 594, 604, 613 TCORA....................... 416, 595, 604, 613 TCORB ....................... 417, 595, 604, 613 TCR..... 312, 417, 594, 595, 604, 613, 614 TCSR .......................... 421, 439, 594, 613 TDR ............................ 454, 594, 603, 612 TGR ............................ 343, 595, 605, 614 TIER ........................... 337, 595, 604, 614 TIOR ........................... 319, 595, 604, 614 TMDR......................... 318, 595, 604, 614 TSR ..................... 339, 455, 595, 604, 614 TSTR........................... 344, 595, 604, 614 TSYR .......................... 345, 595, 604, 614 VBR ...................................................... 28 WTCRA...................... 127, 590, 599, 609 WTCRB ...................... 127, 590, 599, 609 Repeat transfer mode .............................. 237 Reset ......................................................... 72 Reset state ................................................. 59 Resolution ............................................... 538
S
Sample-and-hold circuit.......................... 535 Scan mode............................................... 533 Serial communication interface (SCI)..... 449 Short address mode ................................. 228 Single mode ............................................ 532 Sleep instruction exception handling ........ 80
Sleep mode ..................................... 564, 574 Smart card interface................................ 506 Software standby mode................... 564, 575 Space state .............................................. 481 Stack status after exception handling........ 82 Start bit ................................................... 481 State transitions......................................... 60 Stop bit.................................................... 481 Strobe assert/negate timing..................... 158 Synchronous clearing.............................. 352 Synchronous presetting........................... 352 System clock (I)............................ 146, 553
Transfer information writeback skip function ........................................... 236 Transmit/receive data.............................. 481 Trap instruction exception handling.......... 79
V
Vector table address.................................. 70 Vector table address offset........................ 70
W
Wait control ............................................ 174 Watchdog timer (WDT) .......................... 437 Watchdog timer mode............................. 442 Write data buffer function....................... 211 Write data buffer function for external data bus................................ 211 Write data buffer function for peripheral modules ............................ 212
T
Toggle output.......................................... 349 Trace exception handling.......................... 75 Transfer information............................... 228 Transfer information read skip function ................................... 235
Rev.2.00 Jun. 28, 2007 Page 665 of 666 REJ09B0311-0200
Rev.2.00 Jun. 28, 2007 Page 666 of 666 REJ09B0311-0200
Renesas 32-Bit CISC Microcomputer Hardware Manual H8SX/1650 Group
Publication Date: Rev.1.00, Mar. 28, 2006 Rev.2.00, Jun. 28, 2007 Published by: Sales Strategic Planning Div. Renesas Technology Corp. Edited by: Customer Support Department Global Strategic Communication Div. Renesas Solutions Corp.
2007. Renesas Technology Corp., All rights reserved. Printed in Japan.
Sales Strategic Planning Div.
Nippon Bldg., 2-6-2, Ohte-machi, Chiyoda-ku, Tokyo 100-0004, Japan
RENESAS SALES OFFICES
Refer to "http://www.renesas.com/en/network" for the latest and detailed information. Renesas Technology America, Inc. 450 Holger Way, San Jose, CA 95134-1368, U.S.A Tel: <1> (408) 382-7500, Fax: <1> (408) 382-7501 Renesas Technology Europe Limited Dukes Meadow, Millboard Road, Bourne End, Buckinghamshire, SL8 5FH, U.K. Tel: <44> (1628) 585-100, Fax: <44> (1628) 585-900 Renesas Technology (Shanghai) Co., Ltd. Unit 204, 205, AZIACenter, No.1233 Lujiazui Ring Rd, Pudong District, Shanghai, China 200120 Tel: <86> (21) 5877-1818, Fax: <86> (21) 6887-7898 Renesas Technology Hong Kong Ltd. 7th Floor, North Tower, World Finance Centre, Harbour City, 1 Canton Road, Tsimshatsui, Kowloon, Hong Kong Tel: <852> 2265-6688, Fax: <852> 2730-6071 Renesas Technology Taiwan Co., Ltd. 10th Floor, No.99, Fushing North Road, Taipei, Taiwan Tel: <886> (2) 2715-2888, Fax: <886> (2) 2713-2999 Renesas Technology Singapore Pte. Ltd. 1 Harbour Front Avenue, #06-10, Keppel Bay Tower, Singapore 098632 Tel: <65> 6213-0200, Fax: <65> 6278-8001 Renesas Technology Korea Co., Ltd. Kukje Center Bldg. 18th Fl., 191, 2-ka, Hangang-ro, Yongsan-ku, Seoul 140-702, Korea Tel: <82> (2) 796-3115, Fax: <82> (2) 796-2145
http://www.renesas.com
Renesas Technology Malaysia Sdn. Bhd Unit 906, Block B, Menara Amcorp, Amcorp Trade Centre, No.18, Jalan Persiaran Barat, 46050 Petaling Jaya, Selangor Darul Ehsan, Malaysia Tel: <603> 7955-9390, Fax: <603> 7955-9510
Colophon 6.0
H8SX/1650 Group Hardware Manual


▲Up To Search▲   

 
Price & Availability of R5S61650C

All Rights Reserved © IC-ON-LINE 2003 - 2022  

[Add Bookmark] [Contact Us] [Link exchange] [Privacy policy]
Mirror Sites :  [www.datasheet.hk]   [www.maxim4u.com]  [www.ic-on-line.cn] [www.ic-on-line.com] [www.ic-on-line.net] [www.alldatasheet.com.cn] [www.gdcy.com]  [www.gdcy.net]


 . . . . .
  We use cookies to deliver the best possible web experience and assist with our advertising efforts. By continuing to use this site, you consent to the use of cookies. For more information on cookies, please take a look at our Privacy Policy. X